
<!DOCTYPE HTML>
<html lang="zh-hans" >
    <head>
        <meta charset="UTF-8">
        <meta content="text/html; charset=utf-8" http-equiv="Content-Type">
        <title>分布式文档存储 · Elasticsearch权威指南中文版</title>
        <meta http-equiv="X-UA-Compatible" content="IE=edge" />
        <meta name="description" content="">
        <meta name="generator" content="GitBook 3.2.3">
        <meta name="author" content="WS">
        
        
    
    <link rel="stylesheet" href="gitbook/style.css">

    
            
                
                <link rel="stylesheet" href="gitbook/gitbook-plugin-anchors/plugin.css">
                
            
                
                <link rel="stylesheet" href="gitbook/gitbook-plugin-splitter/splitter.css">
                
            
                
                <link rel="stylesheet" href="gitbook/gitbook-plugin-tbfed-pagefooter/footer.css">
                
            
                
                <link rel="stylesheet" href="gitbook/gitbook-plugin-expandable-chapters-small/expandable-chapters-small.css">
                
            
                
                <link rel="stylesheet" href="gitbook/gitbook-plugin-anchor-navigation-ex/style/plugin.css">
                
            
                
                <link rel="stylesheet" href="gitbook/gitbook-plugin-ace/ace.css">
                
            
                
                <link rel="stylesheet" href="gitbook/gitbook-plugin-emphasize/plugin.css">
                
            
                
                <link rel="stylesheet" href="gitbook/gitbook-plugin-search-plus/search.css">
                
            
                
                <link rel="stylesheet" href="gitbook/gitbook-plugin-highlight/website.css">
                
            
                
                <link rel="stylesheet" href="gitbook/gitbook-plugin-fontsettings/website.css">
                
            
        

    

    
        
    
        
    
        
    
        
    
        
    
        
    

        
    
    
    <meta name="HandheldFriendly" content="true"/>
    <meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no">
    <meta name="apple-mobile-web-app-capable" content="yes">
    <meta name="apple-mobile-web-app-status-bar-style" content="black">
    <link rel="apple-touch-icon-precomposed" sizes="152x152" href="gitbook/images/apple-touch-icon-precomposed-152.png">
    <link rel="shortcut icon" href="gitbook/images/favicon.ico" type="image/x-icon">

    
    <link rel="next" href="2_2_Introductory.html" />
    
    
    <link rel="prev" href="2_1_Introductory.html" />
    

    </head>
    <body>
        
<div class="book">
    <div class="book-summary">
        
            
<div id="book-search-input" role="search">
    <input type="text" placeholder="输入并搜索" />
</div>

            
                <nav role="navigation">
                


<ul class="summary">
    
    

    

    
        
        
    
        <li class="chapter " data-level="1.1" data-path="./">
            
                <a href="./">
            
                    
                    序言
            
                </a>
            

            
        </li>
    

    
        
        <li class="divider"></li>
        
        
    
        <li class="chapter " data-level="2.1" data-path="1Preface.html">
            
                <a href="1Preface.html">
            
                    
                    前言
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="2.1.1" data-path="1Preface.html">
            
                <a href="1Preface.html#谁应该读这本书">
            
                    
                    谁应该读这本书
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.1.2" data-path="1Preface.html">
            
                <a href="1Preface.html#为什么我们要写这本书">
            
                    
                    为什么我们要写这本书
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.1.3" data-path="1Preface.html">
            
                <a href="1Preface.html#Elasticsearch版本">
            
                    
                    Elasticsearch版本
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.1.4" data-path="1Preface.html">
            
                <a href="1Preface.html#如何读这本书">
            
                    
                    如何读这本书
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.1.5" data-path="1Preface.html">
            
                <a href="1Preface.html#本书导航">
            
                    
                    本书导航
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.1.6" data-path="1Preface.html">
            
                <a href="1Preface.html#在线资源">
            
                    
                    在线资源
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.1.7" data-path="1Preface.html">
            
                <a href="1Preface.html#本书协议约定">
            
                    
                    本书协议约定
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.1.8" data-path="1Preface.html">
            
                <a href="1Preface.html#使用代码示例">
            
                    
                    使用代码示例
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="2.1.9" data-path="1Preface.html">
            
                <a href="1Preface.html#鸣谢">
            
                    
                    鸣谢
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    

    
        
        <li class="divider"></li>
        
        
    
        <li class="chapter " data-level="3.1" data-path="2_1_Introductory.html">
            
                <a href="2_1_Introductory.html">
            
                    
                    基础入门
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="3.1.1" data-path="2_1_Introductory.html">
            
                <a href="2_1_Introductory.html#你知道的为了搜索">
            
                    
                    你知道的, 为了搜索…
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="3.1.1.1" data-path="2_1_Introductory.html">
            
                <a href="2_1_Introductory.html#安装并运行Elasticsearch">
            
                    
                    安装并运行Elasticsearch
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.1.2" data-path="2_1_Introductory.html">
            
                <a href="2_1_Introductory.html#安装Sense">
            
                    
                    安装Sense
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.1.3" data-path="2_1_Introductory.html">
            
                <a href="2_1_Introductory.html#和Elasticsearch交互">
            
                    
                    和Elasticsearch交互
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.1.4" data-path="2_1_Introductory.html">
            
                <a href="2_1_Introductory.html#面向文档">
            
                    
                    面向文档
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.1.5" data-path="2_1_Introductory.html">
            
                <a href="2_1_Introductory.html#适应新环境">
            
                    
                    适应新环境
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.1.6" data-path="2_1_Introductory.html">
            
                <a href="2_1_Introductory.html#索引雇员文档">
            
                    
                    索引雇员文档
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.1.7" data-path="2_1_Introductory.html">
            
                <a href="2_1_Introductory.html#检索文档">
            
                    
                    检索文档
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.1.8" data-path="2_1_Introductory.html">
            
                <a href="2_1_Introductory.html#轻量搜索">
            
                    
                    轻量搜索
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.1.9" data-path="2_1_Introductory.html">
            
                <a href="2_1_Introductory.html#使用查询表达式搜索">
            
                    
                    使用查询表达式搜索
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.1.10" data-path="2_1_Introductory.html">
            
                <a href="2_1_Introductory.html#更复杂的搜索">
            
                    
                    更复杂的搜索
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.1.11" data-path="2_1_Introductory.html">
            
                <a href="2_1_Introductory.html#全文搜索">
            
                    
                    全文搜索
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.1.12" data-path="2_1_Introductory.html">
            
                <a href="2_1_Introductory.html#短语搜索">
            
                    
                    短语搜索
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.1.13" data-path="2_1_Introductory.html">
            
                <a href="2_1_Introductory.html#高亮搜索">
            
                    
                    高亮搜索
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.1.14" data-path="2_1_Introductory.html">
            
                <a href="2_1_Introductory.html#分析">
            
                    
                    分析
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.1.15" data-path="2_1_Introductory.html">
            
                <a href="2_1_Introductory.html#教程结语">
            
                    
                    教程结语
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.1.16" data-path="2_1_Introductory.html">
            
                <a href="2_1_Introductory.html#分布式特性">
            
                    
                    分布式特性
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.1.17" data-path="2_1_Introductory.html">
            
                <a href="2_1_Introductory.html#">
            
                    
                    后续步骤
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="3.1.2" data-path="2_1_Introductory.html">
            
                <a href="2_1_Introductory.html#集群内的原理">
            
                    
                    集群内的原理
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="3.1.2.1" data-path="2_1_Introductory.html">
            
                <a href="2_1_Introductory.html#空集群">
            
                    
                    空集群
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.2.2" data-path="2_1_Introductory.html">
            
                <a href="2_1_Introductory.html#集群健康">
            
                    
                    集群健康
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.2.3" data-path="2_1_Introductory.html">
            
                <a href="2_1_Introductory.html#添加索引">
            
                    
                    添加索引
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.2.4" data-path="2_1_Introductory.html">
            
                <a href="2_1_Introductory.html#添加故障转">
            
                    
                    添加故障转
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.2.5" data-path="2_1_Introductory.html">
            
                <a href="2_1_Introductory.html#水平扩容">
            
                    
                    水平扩容
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.2.6" data-path="2_1_Introductory.html">
            
                <a href="2_1_Introductory.html#应对故障">
            
                    
                    应对故障
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="3.1.3" data-path="2_1_Introductory.html">
            
                <a href="2_1_Introductory.html#数据输入和输出">
            
                    
                    数据输入和输出
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="3.1.3.1" data-path="2_1_Introductory.html">
            
                <a href="2_1_Introductory.html#什么是文档">
            
                    
                    什么是文档?
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.3.2" data-path="2_1_Introductory.html">
            
                <a href="2_1_Introductory.html#文档元数据">
            
                    
                    文档元数据
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.3.3" data-path="2_1_Introductory.html">
            
                <a href="2_1_Introductory.html#索引文档">
            
                    
                    索引文档
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.3.4" data-path="2_1_Introductory.html">
            
                <a href="2_1_Introductory.html#取回一个文档">
            
                    
                    取回一个文档
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.3.5" data-path="2_1_Introductory.html">
            
                <a href="2_1_Introductory.html#检查文档是否存在">
            
                    
                    检查文档是否存在
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.3.6" data-path="2_1_Introductory.html">
            
                <a href="2_1_Introductory.html#更新整个文档">
            
                    
                    更新整个文档
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.3.7" data-path="2_1_Introductory.html">
            
                <a href="2_1_Introductory.html#创建新文档">
            
                    
                    创建新文档
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.3.8" data-path="2_1_Introductory.html">
            
                <a href="2_1_Introductory.html#删除文档">
            
                    
                    删除文档
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.3.9" data-path="2_1_Introductory.html">
            
                <a href="2_1_Introductory.html#处理冲突">
            
                    
                    处理冲突
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.3.10" data-path="2_1_Introductory.html">
            
                <a href="2_1_Introductory.html#乐观并发控制">
            
                    
                    乐观并发控制
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.3.11" data-path="2_1_Introductory.html">
            
                <a href="2_1_Introductory.html#文档的部分更新">
            
                    
                    文档的部分更新
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.3.12" data-path="2_1_Introductory.html">
            
                <a href="2_1_Introductory.html#取回多个文档">
            
                    
                    取回多个文档
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.3.13" data-path="2_1_Introductory.html">
            
                <a href="2_1_Introductory.html#代价较小的批量操作">
            
                    
                    代价较小的批量操作
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="3.1.4" data-path="2_2_Introductory.html">
            
                <a href="2_2_Introductory.html#分布式文档存储">
            
                    
                    分布式文档存储
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="3.1.4.1" data-path="2_2_Introductory.html">
            
                <a href="2_2_Introductory.html#路由一个文档到一个分片中">
            
                    
                    路由一个文档到一个分片中
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.4.2" data-path="2_2_Introductory.html">
            
                <a href="2_2_Introductory.html#主分片和副本分片如何交互">
            
                    
                    主分片和副本分片如何交互
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.4.3" data-path="2_2_Introductory.html">
            
                <a href="2_2_Introductory.html#新建索引和删除文档">
            
                    
                    新建、索引和删除文档
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.4.4" data-path="2_2_Introductory.html">
            
                <a href="2_2_Introductory.html#取回一个文档">
            
                    
                    取回一个文档
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.4.5" data-path="2_2_Introductory.html">
            
                <a href="2_2_Introductory.html#局部更新文档">
            
                    
                    局部更新文档
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.4.6" data-path="2_2_Introductory.html">
            
                <a href="2_2_Introductory.html#多文档模式">
            
                    
                    多文档模式
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="3.1.5" data-path="2_2_Introductory.html">
            
                <a href="2_2_Introductory.html#搜索最基本的工具">
            
                    
                    搜索——最基本的工具
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="3.1.5.1" data-path="2_2_Introductory.html">
            
                <a href="2_2_Introductory.html#空搜索">
            
                    
                    空搜索
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.5.2" data-path="2_2_Introductory.html">
            
                <a href="2_2_Introductory.html#多索引多类型">
            
                    
                    多索引，多类型
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.5.3" data-path="2_2_Introductory.html">
            
                <a href="2_2_Introductory.html#分页">
            
                    
                    分页
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.5.4" data-path="2_2_Introductory.html">
            
                <a href="2_2_Introductory.html#轻量搜索">
            
                    
                    轻量搜索
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="3.1.6" data-path="2_2_Introductory.html">
            
                <a href="2_2_Introductory.html#映射和分析">
            
                    
                    映射和分析
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="3.1.6.1" data-path="2_2_Introductory.html">
            
                <a href="2_2_Introductory.html#精确值VS全文">
            
                    
                    精确值 VS 全文
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.6.2" data-path="2_2_Introductory.html">
            
                <a href="2_2_Introductory.html#倒排索引">
            
                    
                    倒排索引
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.6.3" data-path="2_2_Introductory.html">
            
                <a href="2_2_Introductory.html#分析与分析器">
            
                    
                    分析与分析器
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.6.4" data-path="2_2_Introductory.html">
            
                <a href="2_2_Introductory.html#映射">
            
                    
                    映射
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.6.5" data-path="2_2_Introductory.html">
            
                <a href="2_2_Introductory.html#复杂核心域类型">
            
                    
                    复杂核心域类型
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="3.1.7" data-path="2_3_Introductory.html">
            
                <a href="2_3_Introductory.html#请求体查询">
            
                    
                    请求体查询
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="3.1.7.1" data-path="2_3_Introductory.html">
            
                <a href="2_3_Introductory.html#空查询">
            
                    
                    空查询
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.7.2" data-path="2_3_Introductory.html">
            
                <a href="2_3_Introductory.html#查询表达式">
            
                    
                    查询表达式
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.7.3" data-path="2_3_Introductory.html">
            
                <a href="2_3_Introductory.html#查询与过滤">
            
                    
                    查询与过滤
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.7.4" data-path="2_3_Introductory.html">
            
                <a href="2_3_Introductory.html#最重要的查询">
            
                    
                    最重要的查询
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.7.5" data-path="2_3_Introductory.html">
            
                <a href="2_3_Introductory.html#组合多查询">
            
                    
                    组合多查询
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.7.6" data-path="2_3_Introductory.html">
            
                <a href="2_3_Introductory.html#验证查询">
            
                    
                    验证查询
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="3.1.8" data-path="2_3_Introductory.html">
            
                <a href="2_3_Introductory.html#排序与相关性">
            
                    
                    排序与相关性
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="3.1.8.1" data-path="2_3_Introductory.html">
            
                <a href="2_3_Introductory.html#排序">
            
                    
                    排序
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.8.2" data-path="2_3_Introductory.html">
            
                <a href="2_3_Introductory.html#字符串排序与多字段">
            
                    
                    字符串排序与多字段
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.8.3" data-path="2_3_Introductory.html">
            
                <a href="2_3_Introductory.html#什么是相关性">
            
                    
                    什么是相关性?
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.8.4" data-path="2_3_Introductory.html">
            
                <a href="2_3_Introductory.html#DocValues介绍">
            
                    
                    Doc Values 介绍
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="3.1.9" data-path="2_3_Introductory.html">
            
                <a href="2_3_Introductory.html#执行分布式检索">
            
                    
                    执行分布式检索
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="3.1.9.1" data-path="2_3_Introductory.html">
            
                <a href="2_3_Introductory.html#查询阶段">
            
                    
                    查询阶段
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.9.2" data-path="2_3_Introductory.html">
            
                <a href="2_3_Introductory.html#取回阶段">
            
                    
                    取回阶段
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.9.3" data-path="2_3_Introductory.html">
            
                <a href="2_3_Introductory.html#搜索选项">
            
                    
                    搜索选项
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.9.4" data-path="2_3_Introductory.html">
            
                <a href="2_3_Introductory.html#游标查询Scroll">
            
                    
                    游标查询 Scroll
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="3.1.10" data-path="2_4_Introductory.html">
            
                <a href="2_4_Introductory.html#索引管理">
            
                    
                    索引管理
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="3.1.10.1" data-path="2_4_Introductory.html">
            
                <a href="2_4_Introductory.html#创建一个索引">
            
                    
                    创建一个索引
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.10.2" data-path="2_4_Introductory.html">
            
                <a href="2_4_Introductory.html#删除一个索引">
            
                    
                    删除一个索引
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.10.3" data-path="2_4_Introductory.html">
            
                <a href="2_4_Introductory.html#索引设置">
            
                    
                    索引设置
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.10.4" data-path="2_4_Introductory.html">
            
                <a href="2_4_Introductory.html#配置分析器">
            
                    
                    配置分析器
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.10.5" data-path="2_4_Introductory.html">
            
                <a href="2_4_Introductory.html#自定义分析器">
            
                    
                    自定义分析器
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.10.6" data-path="2_4_Introductory.html">
            
                <a href="2_4_Introductory.html#类型和映射">
            
                    
                    类型和映射
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.10.7" data-path="2_4_Introductory.html">
            
                <a href="2_4_Introductory.html#根对象">
            
                    
                    根对象
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.10.8" data-path="2_4_Introductory.html">
            
                <a href="2_4_Introductory.html#动态映射">
            
                    
                    动态映射
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.10.9" data-path="2_4_Introductory.html">
            
                <a href="2_4_Introductory.html#自定义动态映射">
            
                    
                    自定义动态映射
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.10.10" data-path="2_4_Introductory.html">
            
                <a href="2_4_Introductory.html#缺省映射">
            
                    
                    缺省映射
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.10.11" data-path="2_4_Introductory.html">
            
                <a href="2_4_Introductory.html#重新索引你的数据">
            
                    
                    重新索引你的数据
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.10.12" data-path="2_4_Introductory.html">
            
                <a href="2_4_Introductory.html#索引别名和零停机">
            
                    
                    索引别名和零停机
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="3.1.11" data-path="2_4_Introductory.html">
            
                <a href="2_4_Introductory.html#分片内部原理">
            
                    
                    分片内部原理
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="3.1.11.1" data-path="2_4_Introductory.html">
            
                <a href="2_4_Introductory.html#使文本可被搜索">
            
                    
                    使文本可被搜索
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.11.2" data-path="2_4_Introductory.html">
            
                <a href="2_4_Introductory.html#动态更新索引">
            
                    
                    动态更新索引
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.11.3" data-path="2_4_Introductory.html">
            
                <a href="2_4_Introductory.html#近实时搜索">
            
                    
                    近实时搜索
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.11.4" data-path="2_4_Introductory.html">
            
                <a href="2_4_Introductory.html#持久化变更">
            
                    
                    持久化变更
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="3.1.11.5" data-path="2_4_Introductory.html">
            
                <a href="2_4_Introductory.html#段合并">
            
                    
                    段合并
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    

            </ul>
            
        </li>
    

    
        
        <li class="divider"></li>
        
        
    
        <li class="chapter " data-level="4.1" data-path="3_1_DeepSearch.html">
            
                <a href="3_1_DeepSearch.html#深入搜索">
            
                    
                    深入搜索
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="4.1.1" data-path="3_1_DeepSearch.html">
            
                <a href="3_1_DeepSearch.html#结构化搜索">
            
                    
                    结构化搜索
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="4.1.1.1" data-path="3_1_DeepSearch.html">
            
                <a href="3_1_DeepSearch.html#精确值查找">
            
                    
                    精确值查找
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.1.2" data-path="3_1_DeepSearch.html">
            
                <a href="3_1_DeepSearch.html#组合过滤器">
            
                    
                    组合过滤器
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.1.3" data-path="3_1_DeepSearch.html">
            
                <a href="3_1_DeepSearch.html#查找多个精确值">
            
                    
                    查找多个精确值
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.1.4" data-path="3_1_DeepSearch.html">
            
                <a href="3_1_DeepSearch.html#范围">
            
                    
                    范围
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.1.5" data-path="3_1_DeepSearch.html">
            
                <a href="3_1_DeepSearch.html#处理Null值">
            
                    
                    处理 Null 值
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.1.6" data-path="3_1_DeepSearch.html">
            
                <a href="3_1_DeepSearch.html#关于缓存">
            
                    
                    关于缓存
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="4.1.2" data-path="3_1_DeepSearch.html">
            
                <a href="3_1_DeepSearch.html#全文搜索">
            
                    
                    全文搜索
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="4.1.2.1" data-path="3_1_DeepSearch.html">
            
                <a href="3_1_DeepSearch.html#基于词项与基于全文">
            
                    
                    基于词项与基于全文
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.2.2" data-path="3_1_DeepSearch.html">
            
                <a href="3_1_DeepSearch.html#匹配查询">
            
                    
                    匹配查询
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.2.3" data-path="3_1_DeepSearch.html">
            
                <a href="3_1_DeepSearch.html#多词查询">
            
                    
                    多词查询
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.2.4" data-path="3_1_DeepSearch.html">
            
                <a href="3_1_DeepSearch.html#组合查询">
            
                    
                    组合查询
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.2.5" data-path="3_1_DeepSearch.html">
            
                <a href="3_1_DeepSearch.html#如何使用布尔匹配">
            
                    
                    如何使用布尔匹配
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.2.6" data-path="3_1_DeepSearch.html">
            
                <a href="3_1_DeepSearch.html#查询语句提升权重">
            
                    
                    查询语句提升权重
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.2.7" data-path="3_1_DeepSearch.html">
            
                <a href="3_1_DeepSearch.html#控制分析">
            
                    
                    控制分析
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.2.8" data-path="3_1_DeepSearch.html">
            
                <a href="3_1_DeepSearch.html#被破坏的相关度">
            
                    
                    被破坏的相关度！
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="4.1.3" data-path="3_1_DeepSearch.html">
            
                <a href="3_1_DeepSearch.html#多字段搜索">
            
                    
                    多字段搜索
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="4.1.3.1" data-path="3_1_DeepSearch.html">
            
                <a href="3_1_DeepSearch.html#多字符串查询">
            
                    
                    多字符串查询
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.3.2" data-path="3_1_DeepSearch.html">
            
                <a href="3_1_DeepSearch.html#单字符串查询">
            
                    
                    单字符串查询
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.3.3" data-path="3_1_DeepSearch.html">
            
                <a href="3_1_DeepSearch.html#最佳字段">
            
                    
                    最佳字段
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.3.4" data-path="3_1_DeepSearch.html">
            
                <a href="3_1_DeepSearch.html#最佳字段查询调优">
            
                    
                    最佳字段查询调优
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.3.5" data-path="3_1_DeepSearch.html">
            
                <a href="3_1_DeepSearch.html#multi_match查询">
            
                    
                    multi_match 查询
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.3.6" data-path="3_1_DeepSearch.html">
            
                <a href="3_1_DeepSearch.html#多数字段">
            
                    
                    多数字段
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.3.7" data-path="3_1_DeepSearch.html">
            
                <a href="3_1_DeepSearch.html#跨字段实体搜索">
            
                    
                    跨字段实体搜索
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.3.8" data-path="3_1_DeepSearch.html">
            
                <a href="3_1_DeepSearch.html#字段中心式查询">
            
                    
                    字段中心式查询
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.3.9" data-path="3_1_DeepSearch.html">
            
                <a href="3_1_DeepSearch.html#自定义all字段">
            
                    
                    自定义 _all 字段
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.3.10" data-path="3_1_DeepSearch.html">
            
                <a href="3_1_DeepSearch.html#crossfields跨字段查询">
            
                    
                    cross-fields 跨字段查询
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.3.11" data-path="3_1_DeepSearch.html">
            
                <a href="3_1_DeepSearch.html#ExactValue精确值字段">
            
                    
                    Exact-Value 精确值字段
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="4.1.4" data-path="3_2_DeepSearch.html">
            
                <a href="3_2_DeepSearch.html#近似匹配">
            
                    
                    近似匹配
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="4.1.4.1" data-path="3_2_DeepSearch.html">
            
                <a href="3_2_DeepSearch.html#短语匹配">
            
                    
                    短语匹配
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.4.2" data-path="3_2_DeepSearch.html">
            
                <a href="3_2_DeepSearch.html#混合起来">
            
                    
                    混合起来
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.4.3" data-path="3_2_DeepSearch.html">
            
                <a href="3_2_DeepSearch.html#多值字段">
            
                    
                    多值字段
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.4.4" data-path="3_2_DeepSearch.html">
            
                <a href="3_2_DeepSearch.html#越近越好">
            
                    
                    越近越好
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.4.5" data-path="3_2_DeepSearch.html">
            
                <a href="3_2_DeepSearch.html#使用邻近度提高相关度">
            
                    
                    使用邻近度提高相关度
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.4.6" data-path="3_2_DeepSearch.html">
            
                <a href="3_2_DeepSearch.html#性能优化">
            
                    
                    性能优化
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.4.7" data-path="3_2_DeepSearch.html">
            
                <a href="3_2_DeepSearch.html#寻找相关词">
            
                    
                    寻找相关词
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="4.1.5" data-path="3_2_DeepSearch.html">
            
                <a href="3_2_DeepSearch.html#部分匹配">
            
                    
                    部分匹配
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="4.1.5.1" data-path="3_2_DeepSearch.html">
            
                <a href="3_2_DeepSearch.html#邮编与结构化数据">
            
                    
                    邮编与结构化数据
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.5.2" data-path="3_2_DeepSearch.html">
            
                <a href="3_2_DeepSearch.html#prefix前缀查询">
            
                    
                    prefix 前缀查询
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.5.3" data-path="3_2_DeepSearch.html">
            
                <a href="3_2_DeepSearch.html#通配符与正则表达式查询">
            
                    
                    通配符与正则表达式查询
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.5.4" data-path="3_2_DeepSearch.html">
            
                <a href="3_2_DeepSearch.html#查询时输入即搜索">
            
                    
                    查询时输入即搜索
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.5.5" data-path="3_2_DeepSearch.html">
            
                <a href="3_2_DeepSearch.html#索引时优化">
            
                    
                    索引时优化
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.5.6" data-path="3_2_DeepSearch.html">
            
                <a href="3_2_DeepSearch.html#Ngrams在部分匹配的应用">
            
                    
                    Ngrams 在部分匹配的应用
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.5.7" data-path="3_2_DeepSearch.html">
            
                <a href="3_2_DeepSearch.html#索引时输入即搜索">
            
                    
                    索引时输入即搜索
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.5.8" data-path="3_2_DeepSearch.html">
            
                <a href="3_2_DeepSearch.html#Ngrams在复合词的应用">
            
                    
                    Ngrams 在复合词的应用
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="4.1.6" data-path="3_2_DeepSearch.html">
            
                <a href="3_2_DeepSearch.html#控制相关度">
            
                    
                    控制相关度
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="4.1.6.1" data-path="3_2_DeepSearch.html">
            
                <a href="3_2_DeepSearch.html#相关度评分背后的理论">
            
                    
                    相关度评分背后的理论
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.6.2" data-path="3_2_DeepSearch.html">
            
                <a href="3_2_DeepSearch.html#Lucene的实用评分函数">
            
                    
                    Lucene 的实用评分函数
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.6.3" data-path="3_2_DeepSearch.html">
            
                <a href="3_2_DeepSearch.html#查询时权重提升">
            
                    
                    查询时权重提升
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.6.4" data-path="3_2_DeepSearch.html">
            
                <a href="3_2_DeepSearch.html#使用查询结构修改相关度">
            
                    
                    使用查询结构修改相关度
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.6.5" data-path="3_2_DeepSearch.html">
            
                <a href="3_2_DeepSearch.html#NotQuiteNot">
            
                    
                    Not Quite Not
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.6.6" data-path="3_2_DeepSearch.html">
            
                <a href="3_2_DeepSearch.html#忽略TFIDF">
            
                    
                    忽略 TF/IDF
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.6.7" data-path="3_2_DeepSearch.html">
            
                <a href="3_2_DeepSearch.html#functionscore查询">
            
                    
                    function_score 查询
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.6.8" data-path="3_2_DeepSearch.html">
            
                <a href="3_2_DeepSearch.html#按受欢迎度提升权重">
            
                    
                    按受欢迎度提升权重
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.6.9" data-path="3_2_DeepSearch.html">
            
                <a href="3_2_DeepSearch.html#过滤集提升权重">
            
                    
                    过滤集提升权重
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.6.10" data-path="3_2_DeepSearch.html">
            
                <a href="3_2_DeepSearch.html#随机评分">
            
                    
                    随机评分
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.6.11" data-path="3_2_DeepSearch.html">
            
                <a href="3_2_DeepSearch.html#越近越好">
            
                    
                    越近越好
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.6.12" data-path="3_2_DeepSearch.html">
            
                <a href="3_2_DeepSearch.html#理解price价格语句">
            
                    
                    理解 price 价格语句
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.6.13" data-path="3_2_DeepSearch.html">
            
                <a href="3_2_DeepSearch.html#脚本评分">
            
                    
                    脚本评分
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.6.14" data-path="3_2_DeepSearch.html">
            
                <a href="3_2_DeepSearch.html#可插拔的相似度算法">
            
                    
                    可插拔的相似度算法
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.6.15" data-path="3_2_DeepSearch.html">
            
                <a href="3_2_DeepSearch.html#更改相似度">
            
                    
                    更改相似度
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="4.1.6.16" data-path="3_2_DeepSearch.html">
            
                <a href="3_2_DeepSearch.html#调试相关度是最后10要做的事情">
            
                    
                    调试相关度是最后 10% 要做的事情
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    

            </ul>
            
        </li>
    

    
        
        <li class="divider"></li>
        
        
    
        <li class="chapter " data-level="5.1" data-path="4_1_Dealing_with_language.html">
            
                <a href="4_1_Dealing_with_language.html#处理人类语言">
            
                    
                    处理人类语言
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="5.1.1" data-path="4_1_Dealing_with_language.html">
            
                <a href="4_1_Dealing_with_language.html#开始处理各种语言">
            
                    
                    开始处理各种语言
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="5.1.1.1" data-path="4_1_Dealing_with_language.html">
            
                <a href="4_1_Dealing_with_language.html#使用语言分析器">
            
                    
                    使用语言分析器
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.1.2" data-path="4_1_Dealing_with_language.html">
            
                <a href="4_1_Dealing_with_language.html#配置语言分析器">
            
                    
                    配置语言分析器
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.1.3" data-path="4_1_Dealing_with_language.html">
            
                <a href="4_1_Dealing_with_language.html#混合语言的陷阱">
            
                    
                    混合语言的陷阱
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.1.4" data-path="4_1_Dealing_with_language.html">
            
                <a href="4_1_Dealing_with_language.html#每份文档一种语言">
            
                    
                    每份文档一种语言
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.1.5" data-path="4_1_Dealing_with_language.html">
            
                <a href="4_1_Dealing_with_language.html#每个域一种语言">
            
                    
                    每个域一种语言
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.1.6" data-path="4_1_Dealing_with_language.html">
            
                <a href="4_1_Dealing_with_language.html#混合语言域">
            
                    
                    混合语言域
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="5.1.2" data-path="4_1_Dealing_with_language.html">
            
                <a href="4_1_Dealing_with_language.html#词汇识别">
            
                    
                    词汇识别
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="5.1.2.1" data-path="4_1_Dealing_with_language.html">
            
                <a href="4_1_Dealing_with_language.html#标准分析器">
            
                    
                    标准分析器
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.2.2" data-path="4_1_Dealing_with_language.html">
            
                <a href="4_1_Dealing_with_language.html#标准分词器">
            
                    
                    标准分词器
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.2.3" data-path="4_1_Dealing_with_language.html">
            
                <a href="4_1_Dealing_with_language.html#安装ICU插件">
            
                    
                    安装 ICU 插件
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.2.4" data-path="4_1_Dealing_with_language.html">
            
                <a href="4_1_Dealing_with_language.html#icu分词器">
            
                    
                    icu_分词器
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.2.5" data-path="4_1_Dealing_with_language.html">
            
                <a href="4_1_Dealing_with_language.html#整理输入文本">
            
                    
                    整理输入文本
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="5.1.3" data-path="4_1_Dealing_with_language.html">
            
                <a href="4_1_Dealing_with_language.html#归一化词元">
            
                    
                    归一化词元
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="5.1.3.1" data-path="4_1_Dealing_with_language.html">
            
                <a href="4_1_Dealing_with_language.html#举个例子">
            
                    
                    举个例子
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.3.2" data-path="4_1_Dealing_with_language.html">
            
                <a href="4_1_Dealing_with_language.html#如果有口音">
            
                    
                    如果有口音
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.3.3" data-path="4_1_Dealing_with_language.html">
            
                <a href="4_1_Dealing_with_language.html#Unicode的世界">
            
                    
                    Unicode的世界
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.3.4" data-path="4_1_Dealing_with_language.html">
            
                <a href="4_1_Dealing_with_language.html#Unicode大小写折叠">
            
                    
                    Unicode 大小写折叠
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.3.5" data-path="4_1_Dealing_with_language.html">
            
                <a href="4_1_Dealing_with_language.html#Unicode字符折叠">
            
                    
                    Unicode 字符折叠
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.3.6" data-path="4_1_Dealing_with_language.html">
            
                <a href="4_1_Dealing_with_language.html#排序和整理">
            
                    
                    排序和整理
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="5.1.4" data-path="4_1_Dealing_with_language.html">
            
                <a href="4_1_Dealing_with_language.html#将单词还原为词根">
            
                    
                    将单词还原为词根
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="5.1.4.1" data-path="4_1_Dealing_with_language.html">
            
                <a href="4_1_Dealing_with_language.html#词干提取算法">
            
                    
                    词干提取算法
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.4.2" data-path="4_1_Dealing_with_language.html">
            
                <a href="4_1_Dealing_with_language.html#字典词干提取器">
            
                    
                    字典词干提取器
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.4.3" data-path="4_1_Dealing_with_language.html">
            
                <a href="4_1_Dealing_with_language.html#Hunspell词干提取器">
            
                    
                    Hunspell 词干提取器
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.4.4" data-path="4_1_Dealing_with_language.html">
            
                <a href="4_1_Dealing_with_language.html#选择一个词干提取器">
            
                    
                    选择一个词干提取器
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.4.5" data-path="4_1_Dealing_with_language.html">
            
                <a href="4_1_Dealing_with_language.html#控制词干提取">
            
                    
                    控制词干提取
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.4.6" data-path="4_1_Dealing_with_language.html">
            
                <a href="4_1_Dealing_with_language.html#原形词干提取">
            
                    
                    原形词干提取
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="5.1.5" data-path="4_2_Dealing_with_language.html">
            
                <a href="4_2_Dealing_with_language.html#停用词性能与精度">
            
                    
                    停用词: 性能与精度
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="5.1.5.1" data-path="4_2_Dealing_with_language.html">
            
                <a href="4_2_Dealing_with_language.html#停用词的优缺点">
            
                    
                    停用词的优缺点
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.5.2" data-path="4_2_Dealing_with_language.html">
            
                <a href="4_2_Dealing_with_language.html#使用停用词">
            
                    
                    使用停用词
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.5.3" data-path="4_2_Dealing_with_language.html">
            
                <a href="4_2_Dealing_with_language.html#停用词与性能">
            
                    
                    停用词与性能
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.5.4" data-path="4_2_Dealing_with_language.html">
            
                <a href="4_2_Dealing_with_language.html#词项的分别管理">
            
                    
                    词项的分别管理
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.5.5" data-path="4_2_Dealing_with_language.html">
            
                <a href="4_2_Dealing_with_language.html#停用词与短语查询">
            
                    
                    停用词与短语查询
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.5.6" data-path="4_2_Dealing_with_language.html">
            
                <a href="4_2_Dealing_with_language.html#commongrams过滤器">
            
                    
                    common_grams 过滤器
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.5.7" data-path="4_2_Dealing_with_language.html">
            
                <a href="4_2_Dealing_with_language.html#停用词与相关性">
            
                    
                    停用词与相关性
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="5.1.6" data-path="4_2_Dealing_with_language.html">
            
                <a href="4_2_Dealing_with_language.html#同义词">
            
                    
                    同义词
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="5.1.6.1" data-path="4_2_Dealing_with_language.html">
            
                <a href="4_2_Dealing_with_language.html#使用同义词">
            
                    
                    使用同义词
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.6.2" data-path="4_2_Dealing_with_language.html">
            
                <a href="4_2_Dealing_with_language.html#同义词格式">
            
                    
                    同义词格式
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.6.3" data-path="4_2_Dealing_with_language.html">
            
                <a href="4_2_Dealing_with_language.html#扩展或收缩">
            
                    
                    扩展或收缩
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.6.4" data-path="4_2_Dealing_with_language.html">
            
                <a href="4_2_Dealing_with_language.html#同义词和分析链">
            
                    
                    同义词和分析链
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.6.5" data-path="4_2_Dealing_with_language.html">
            
                <a href="4_2_Dealing_with_language.html#多词同义词和短语查询">
            
                    
                    多词同义词和短语查询
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.6.6" data-path="4_2_Dealing_with_language.html">
            
                <a href="4_2_Dealing_with_language.html#符号同义词">
            
                    
                    符号同义词
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="5.1.7" data-path="4_2_Dealing_with_language.html">
            
                <a href="4_2_Dealing_with_language.html#拼写错误">
            
                    
                    拼写错误
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="5.1.7.1" data-path="4_2_Dealing_with_language.html">
            
                <a href="4_2_Dealing_with_language.html#模糊性">
            
                    
                    模糊性
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.7.2" data-path="4_2_Dealing_with_language.html">
            
                <a href="4_2_Dealing_with_language.html#模糊查询">
            
                    
                    模糊查询
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.7.3" data-path="4_2_Dealing_with_language.html">
            
                <a href="4_2_Dealing_with_language.html#模糊匹配查询">
            
                    
                    模糊匹配查询
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.7.4" data-path="4_2_Dealing_with_language.html">
            
                <a href="4_2_Dealing_with_language.html#模糊性评分">
            
                    
                    模糊性评分
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="5.1.7.5" data-path="4_2_Dealing_with_language.html">
            
                <a href="4_2_Dealing_with_language.html#语音匹配">
            
                    
                    语音匹配
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    

            </ul>
            
        </li>
    

    
        
        <li class="divider"></li>
        
        
    
        <li class="chapter " data-level="6.1" data-path="5_1_Aggregations.html">
            
                <a href="5_1_Aggregations.html#聚合">
            
                    
                    聚合
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="6.1.1" data-path="5_1_Aggregations.html">
            
                <a href="5_1_Aggregations.html#高阶概念">
            
                    
                    高阶概念
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="6.1.1.1" data-path="5_1_Aggregations.html">
            
                <a href="5_1_Aggregations.html#桶">
            
                    
                    桶
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="6.1.1.2" data-path="5_1_Aggregations.html">
            
                <a href="5_1_Aggregations.html#指标">
            
                    
                    指标
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="6.1.1.3" data-path="5_1_Aggregations.html">
            
                <a href="5_1_Aggregations.html#桶和指标的组合">
            
                    
                    桶和指标的组合
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="6.1.2" data-path="5_1_Aggregations.html">
            
                <a href="5_1_Aggregations.html#尝试聚合">
            
                    
                    尝试聚合
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="6.1.2.1" data-path="5_1_Aggregations.html">
            
                <a href="5_1_Aggregations.html#添加度量指标">
            
                    
                    添加度量指标
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="6.1.2.2" data-path="5_1_Aggregations.html">
            
                <a href="5_1_Aggregations.html#嵌套桶">
            
                    
                    嵌套桶
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="6.1.2.3" data-path="5_1_Aggregations.html">
            
                <a href="5_1_Aggregations.html#最后的修改">
            
                    
                    最后的修改
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="6.1.3" data-path="5_1_Aggregations.html">
            
                <a href="5_1_Aggregations.html#条形图">
            
                    
                    条形图
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="6.1.4" data-path="5_1_Aggregations.html">
            
                <a href="5_1_Aggregations.html#按时间统计">
            
                    
                    按时间统计
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="6.1.4.1" data-path="5_1_Aggregations.html">
            
                <a href="5_1_Aggregations.html#返回空Buckets">
            
                    
                    返回空 Buckets
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="6.1.4.2" data-path="5_1_Aggregations.html">
            
                <a href="5_1_Aggregations.html#扩展例子">
            
                    
                    扩展例子
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="6.1.4.3" data-path="5_1_Aggregations.html">
            
                <a href="5_1_Aggregations.html#潜力无穷">
            
                    
                    潜力无穷
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="6.1.5" data-path="5_1_Aggregations.html">
            
                <a href="5_1_Aggregations.html#范围限定的聚合">
            
                    
                    范围限定的聚合
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="6.1.6" data-path="5_2_Aggregations.html">
            
                <a href="5_2_Aggregations.html#过滤和聚合">
            
                    
                    过滤和聚合
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="6.1.6.1" data-path="5_2_Aggregations.html">
            
                <a href="5_2_Aggregations.html#过滤">
            
                    
                    过滤
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="6.1.6.2" data-path="5_2_Aggregations.html">
            
                <a href="5_2_Aggregations.html#过滤桶">
            
                    
                    过滤桶
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="6.1.6.3" data-path="5_2_Aggregations.html">
            
                <a href="5_2_Aggregations.html#后过滤器">
            
                    
                    后过滤器
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="6.1.6.4" data-path="5_2_Aggregations.html">
            
                <a href="5_2_Aggregations.html#小结5_2">
            
                    
                    小结
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="6.1.7" data-path="5_2_Aggregations.html">
            
                <a href="5_2_Aggregations.html#多桶排序">
            
                    
                    多桶排序
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="6.1.7.1" data-path="5_2_Aggregations.html">
            
                <a href="5_2_Aggregations.html#内置排序">
            
                    
                    内置排序
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="6.1.7.2" data-path="5_2_Aggregations.html">
            
                <a href="5_2_Aggregations.html#按度量排序">
            
                    
                    按度量排序
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="6.1.7.3" data-path="5_2_Aggregations.html">
            
                <a href="5_2_Aggregations.html#基于深度度量排序">
            
                    
                    基于“深度”度量排序
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="6.1.8" data-path="5_2_Aggregations.html">
            
                <a href="5_2_Aggregations.html#近似聚合">
            
                    
                    近似聚合
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="6.1.8.1" data-path="5_2_Aggregations.html">
            
                <a href="5_2_Aggregations.html#统计去重后的数量">
            
                    
                    统计去重后的数量
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="6.1.8.2" data-path="5_2_Aggregations.html">
            
                <a href="5_2_Aggregations.html#百分位计算">
            
                    
                    百分位计算
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="6.1.9" data-path="5_2_Aggregations.html">
            
                <a href="5_2_Aggregations.html#通过聚合发现异常指标">
            
                    
                    通过聚合发现异常指标
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="6.1.9.1" data-path="5_2_Aggregations.html">
            
                <a href="5_2_Aggregations.html#significantterms演示">
            
                    
                    significant_terms 演示
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="6.1.10" data-path="5_2_Aggregations.html">
            
                <a href="5_2_Aggregations.html#DocValuesandFielddata">
            
                    
                    Doc Values and Fielddata
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="6.1.10.1" data-path="5_2_Aggregations.html">
            
                <a href="5_2_Aggregations.html#DocValues">
            
                    
                    Doc Values
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="6.1.10.2" data-path="5_2_Aggregations.html">
            
                <a href="5_2_Aggregations.html#深入理解DocValues">
            
                    
                    深入理解 Doc Values
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="6.1.10.3" data-path="5_2_Aggregations.html">
            
                <a href="5_2_Aggregations.html#聚合与分析">
            
                    
                    聚合与分析
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="6.1.10.4" data-path="5_2_Aggregations.html">
            
                <a href="5_2_Aggregations.html#限制内存使用">
            
                    
                    限制内存使用
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="6.1.10.5" data-path="5_2_Aggregations.html">
            
                <a href="5_2_Aggregations.html#Fielddata的过滤">
            
                    
                    Fielddata 的过滤
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="6.1.10.6" data-path="5_2_Aggregations.html">
            
                <a href="5_2_Aggregations.html#预加载fielddata">
            
                    
                    预加载 fielddata
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="6.1.10.7" data-path="5_2_Aggregations.html">
            
                <a href="5_2_Aggregations.html#优化聚合查询">
            
                    
                    优化聚合查询
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="6.1.11" data-path="5_2_Aggregations.html">
            
                <a href="5_2_Aggregations.html#总结5_2">
            
                    
                    总结
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    

    
        
        <li class="divider"></li>
        
        
    
        <li class="chapter " data-level="7.1" data-path="6_Geolocation.html">
            
                <a href="6_Geolocation.html#地理位置">
            
                    
                    地理位置
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="7.1.1" data-path="6_Geolocation.html">
            
                <a href="6_Geolocation.html#地理坐标点">
            
                    
                    地理坐标点
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="7.1.1.1" data-path="6_Geolocation.html">
            
                <a href="6_Geolocation.html#经纬度坐标格式">
            
                    
                    经纬度坐标格式
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.1.1.2" data-path="6_Geolocation.html">
            
                <a href="6_Geolocation.html#通过地理坐标点过滤">
            
                    
                    通过地理坐标点过滤
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.1.1.3" data-path="6_Geolocation.html">
            
                <a href="6_Geolocation.html#地理坐标盒模型过滤器">
            
                    
                    地理坐标盒模型过滤器
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.1.1.4" data-path="6_Geolocation.html">
            
                <a href="6_Geolocation.html#地理距离过滤器">
            
                    
                    地理距离过滤器
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.1.1.5" data-path="6_Geolocation.html">
            
                <a href="6_Geolocation.html#按距离排序">
            
                    
                    按距离排序
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="7.1.2" data-path="6_Geolocation.html">
            
                <a href="6_Geolocation.html#Geohashes6">
            
                    
                    Geohashes
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="7.1.2.1" data-path="6_Geolocation.html">
            
                <a href="6_Geolocation.html#Geohashes映射">
            
                    
                    Geohashes 映射
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.1.2.2" data-path="6_Geolocation.html">
            
                <a href="6_Geolocation.html#Geohash单元查询">
            
                    
                    Geohash 单元查询
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="7.1.3" data-path="6_Geolocation.html">
            
                <a href="6_Geolocation.html#地理位置聚合">
            
                    
                    地理位置聚合
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="7.1.3.1" data-path="6_Geolocation.html">
            
                <a href="6_Geolocation.html#地理距离聚合">
            
                    
                    地理距离聚合
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.1.3.2" data-path="6_Geolocation.html">
            
                <a href="6_Geolocation.html#Geohash网格聚合">
            
                    
                    Geohash 网格聚合
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.1.3.3" data-path="6_Geolocation.html">
            
                <a href="6_Geolocation.html#地理边界聚合">
            
                    
                    地理边界聚合
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="7.1.4" data-path="6_Geolocation.html">
            
                <a href="6_Geolocation.html#地理形状">
            
                    
                    地理形状
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="7.1.4.1" data-path="6_Geolocation.html">
            
                <a href="6_Geolocation.html#映射地理形状">
            
                    
                    映射地理形状
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.1.4.2" data-path="6_Geolocation.html">
            
                <a href="6_Geolocation.html#索引地理形状">
            
                    
                    索引地理形状
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.1.4.3" data-path="6_Geolocation.html">
            
                <a href="6_Geolocation.html#查询地理形状">
            
                    
                    查询地理形状
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="7.1.4.4" data-path="6_Geolocation.html">
            
                <a href="6_Geolocation.html#在查询中使用已索引的形状">
            
                    
                    在查询中使用已索引的形状
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    

            </ul>
            
        </li>
    

    
        
        <li class="divider"></li>
        
        
    
        <li class="chapter " data-level="8.1" data-path="7_Modeling_your_data.html">
            
                <a href="7_Modeling_your_data.html#数据建模">
            
                    
                    数据建模
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="8.1.1" data-path="7_Modeling_your_data.html">
            
                <a href="7_Modeling_your_data.html#关联关系处理">
            
                    
                    关联关系处理
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="8.1.1.1" data-path="7_Modeling_your_data.html">
            
                <a href="7_Modeling_your_data.html#应用层联接">
            
                    
                    应用层联接
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.1.2" data-path="7_Modeling_your_data.html">
            
                <a href="7_Modeling_your_data.html#非规范化你的数据">
            
                    
                    非规范化你的数据
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.1.3" data-path="7_Modeling_your_data.html">
            
                <a href="7_Modeling_your_data.html#字段折叠">
            
                    
                    字段折叠
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.1.4" data-path="7_Modeling_your_data.html">
            
                <a href="7_Modeling_your_data.html#非规范化和并发">
            
                    
                    非规范化和并发
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.1.5" data-path="7_Modeling_your_data.html">
            
                <a href="7_Modeling_your_data.html#解决并发问题">
            
                    
                    解决并发问题
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="8.1.2" data-path="7_Modeling_your_data.html">
            
                <a href="7_Modeling_your_data.html#嵌套对象">
            
                    
                    嵌套对象
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="8.1.2.1" data-path="7_Modeling_your_data.html">
            
                <a href="7_Modeling_your_data.html#嵌套对象映射">
            
                    
                    嵌套对象映射
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.2.2" data-path="7_Modeling_your_data.html">
            
                <a href="7_Modeling_your_data.html#嵌套对象查询">
            
                    
                    嵌套对象查询
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.2.3" data-path="7_Modeling_your_data.html">
            
                <a href="7_Modeling_your_data.html#使用嵌套字段排序">
            
                    
                    使用嵌套字段排序
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.2.4" data-path="7_Modeling_your_data.html">
            
                <a href="7_Modeling_your_data.html#嵌套聚合">
            
                    
                    嵌套聚合
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="8.1.3" data-path="7_Modeling_your_data.html">
            
                <a href="7_Modeling_your_data.html#父子关系文档">
            
                    
                    父-子关系文档
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="8.1.3.1" data-path="7_Modeling_your_data.html">
            
                <a href="7_Modeling_your_data.html#父子关系文档映射">
            
                    
                    父-子关系文档映射
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.3.2" data-path="7_Modeling_your_data.html">
            
                <a href="7_Modeling_your_data.html#构建父子文档索引">
            
                    
                    构建父-子文档索引
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.3.3" data-path="7_Modeling_your_data.html">
            
                <a href="7_Modeling_your_data.html#通过子文档查询父文档">
            
                    
                    通过子文档查询父文档
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.3.4" data-path="7_Modeling_your_data.html">
            
                <a href="7_Modeling_your_data.html#通过父文档查询子文档">
            
                    
                    通过父文档查询子文档
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.3.5" data-path="7_Modeling_your_data.html">
            
                <a href="7_Modeling_your_data.html#子文档聚合">
            
                    
                    子文档聚合
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.3.6" data-path="7_Modeling_your_data.html">
            
                <a href="7_Modeling_your_data.html#祖辈与孙辈关系">
            
                    
                    祖辈与孙辈关系
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.3.7" data-path="7_Modeling_your_data.html">
            
                <a href="7_Modeling_your_data.html#实际使用中的一些建议">
            
                    
                    实际使用中的一些建议
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="8.1.4" data-path="7_Modeling_your_data.html">
            
                <a href="7_Modeling_your_data.html#扩容设计">
            
                    
                    扩容设计
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="8.1.4.1" data-path="7_Modeling_your_data.html">
            
                <a href="7_Modeling_your_data.html#扩容的单元">
            
                    
                    扩容的单元
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.4.2" data-path="7_Modeling_your_data.html">
            
                <a href="7_Modeling_your_data.html#分片预分配">
            
                    
                    分片预分配
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.4.3" data-path="7_Modeling_your_data.html">
            
                <a href="7_Modeling_your_data.html#海量分片">
            
                    
                    海量分片
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.4.4" data-path="7_Modeling_your_data.html">
            
                <a href="7_Modeling_your_data.html#容量规划">
            
                    
                    容量规划
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.4.5" data-path="7_Modeling_your_data.html">
            
                <a href="7_Modeling_your_data.html#副本分片">
            
                    
                    副本分片
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.4.6" data-path="7_Modeling_your_data.html">
            
                <a href="7_Modeling_your_data.html#多索引">
            
                    
                    多索引
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.4.7" data-path="7_Modeling_your_data.html">
            
                <a href="7_Modeling_your_data.html#基于时间的数据">
            
                    
                    基于时间的数据
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.4.8" data-path="7_Modeling_your_data.html">
            
                <a href="7_Modeling_your_data.html#索引模板">
            
                    
                    索引模板
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.4.9" data-path="7_Modeling_your_data.html">
            
                <a href="7_Modeling_your_data.html#数据过期">
            
                    
                    数据过期
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.4.10" data-path="7_Modeling_your_data.html">
            
                <a href="7_Modeling_your_data.html#基于用户的数据">
            
                    
                    基于用户的数据
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.4.11" data-path="7_Modeling_your_data.html">
            
                <a href="7_Modeling_your_data.html#共享索引">
            
                    
                    共享索引
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.4.12" data-path="7_Modeling_your_data.html">
            
                <a href="7_Modeling_your_data.html#利用别名实现一个用户一个索引">
            
                    
                    利用别名实现一个用户一个索引
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.4.13" data-path="7_Modeling_your_data.html">
            
                <a href="7_Modeling_your_data.html#一个大的用户">
            
                    
                    一个大的用户
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="8.1.4.14" data-path="7_Modeling_your_data.html">
            
                <a href="7_Modeling_your_data.html#扩容并不是无限的">
            
                    
                    扩容并不是无限的
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    

            </ul>
            
        </li>
    

    
        
        <li class="divider"></li>
        
        
    
        <li class="chapter " data-level="9.1" data-path="8_Admin.html">
            
                <a href="8_Admin.html#管理监控和部署">
            
                    
                    管理、监控和部署
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="9.1.1" data-path="8_Admin.html">
            
                <a href="8_Admin.html#监控">
            
                    
                    监控
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="9.1.1.1" data-path="8_Admin.html">
            
                <a href="8_Admin.html#Marvel监控">
            
                    
                    Marvel 监控
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.1.2" data-path="8_Admin.html">
            
                <a href="8_Admin.html#集群健康">
            
                    
                    集群健康
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.1.3" data-path="8_Admin.html">
            
                <a href="8_Admin.html#监控单个节点">
            
                    
                    监控单个节点
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.1.4" data-path="8_Admin.html">
            
                <a href="8_Admin.html#集群统计">
            
                    
                    集群统计
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.1.5" data-path="8_Admin.html">
            
                <a href="8_Admin.html#索引统计">
            
                    
                    索引统计
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.1.6" data-path="8_Admin.html">
            
                <a href="8_Admin.html#等待中的任务">
            
                    
                    等待中的任务
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.1.7" data-path="8_Admin.html">
            
                <a href="8_Admin.html#catAPI">
            
                    
                    cat API
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="9.1.2" data-path="8_Admin.html">
            
                <a href="8_Admin.html#部署">
            
                    
                    部署
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="9.1.2.1" data-path="8_Admin.html">
            
                <a href="8_Admin.html#硬件">
            
                    
                    硬件
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.2.2" data-path="8_Admin.html">
            
                <a href="8_Admin.html#Java虚拟机">
            
                    
                    Java 虚拟机
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.2.3" data-path="8_Admin.html">
            
                <a href="8_Admin.html#TransportClient与NodeClient">
            
                    
                    Transport Client 与 Node Client
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.2.4" data-path="8_Admin.html">
            
                <a href="8_Admin.html#配置管理">
            
                    
                    配置管理
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.2.5" data-path="8_Admin.html">
            
                <a href="8_Admin.html#重要配置的修改">
            
                    
                    重要配置的修改
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.2.6" data-path="8_Admin.html">
            
                <a href="8_Admin.html#不要触碰这些配置">
            
                    
                    不要触碰这些配置！
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.2.7" data-path="8_Admin.html">
            
                <a href="8_Admin.html#堆内存大小和交换">
            
                    
                    堆内存:大小和交换
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.2.8" data-path="8_Admin.html">
            
                <a href="8_Admin.html#文件描述符和MMap">
            
                    
                    文件描述符和 MMap
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.2.9" data-path="8_Admin.html">
            
                <a href="8_Admin.html#在生产之前，重温这个列表">
            
                    
                    在生产之前，重温这个列表
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="9.1.3" data-path="8_Admin.html">
            
                <a href="8_Admin.html#部署后">
            
                    
                    部署后
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="9.1.3.1" data-path="8_Admin.html">
            
                <a href="8_Admin.html#动态变更设置">
            
                    
                    动态变更设置
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.3.2" data-path="8_Admin.html">
            
                <a href="8_Admin.html#日志记录">
            
                    
                    日志记录
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.3.3" data-path="8_Admin.html">
            
                <a href="8_Admin.html#索引性能技巧">
            
                    
                    索引性能技巧
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.3.4" data-path="8_Admin.html">
            
                <a href="8_Admin.html#推迟分片分配">
            
                    
                    推迟分片分配
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.3.5" data-path="8_Admin.html">
            
                <a href="8_Admin.html#滚动重启">
            
                    
                    滚动重启
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.3.6" data-path="8_Admin.html">
            
                <a href="8_Admin.html#备份你的集群">
            
                    
                    备份你的集群
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.3.7" data-path="8_Admin.html">
            
                <a href="8_Admin.html#从快照恢复">
            
                    
                    从快照恢复
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="9.1.3.8" data-path="8_Admin.html">
            
                <a href="8_Admin.html#集群是活着的呼吸着的生命">
            
                    
                    集群是活着的、呼吸着的生命
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    

            </ul>
            
        </li>
    

    

    <li class="divider"></li>

    <li>
        <a href="https://www.gitbook.com" target="blank" class="gitbook-link">
            本书使用 GitBook 发布
        </a>
    </li>
</ul>


                </nav>
            
        
    </div>

    <div class="book-body">
        
            <div class="body-inner">
                
                    

<div class="book-header" role="navigation">
    

    <!-- Title -->
    <h1>
        <i class="fa fa-circle-o-notch fa-spin"></i>
        <a href="." >分布式文档存储</a>
    </h1>
</div>




                    <div class="page-wrapper" tabindex="-1" role="main">
                        <div class="page-inner">
                            
<div class="search-plus" id="book-search-results">
    <div class="search-noresults">
    
                                <section class="normal markdown-section">
                                
                                <div id="anchor-navigation-ex-navbar"><i class="fa fa-anchor"></i><ul><li><a href="#&#x57FA;&#x7840;&#x5165;&#x95E8;">&#x57FA;&#x7840;&#x5165;&#x95E8;</a></li><ul><li><a href="#&#x5206;&#x5E03;&#x5F0F;&#x6587;&#x6863;&#x5B58;&#x50A8;">&#x5206;&#x5E03;&#x5F0F;&#x6587;&#x6863;&#x5B58;&#x50A8;</a></li><ul><li><a href="#&#x8DEF;&#x7531;&#x4E00;&#x4E2A;&#x6587;&#x6863;&#x5230;&#x4E00;&#x4E2A;&#x5206;&#x7247;&#x4E2D;">&#x8DEF;&#x7531;&#x4E00;&#x4E2A;&#x6587;&#x6863;&#x5230;&#x4E00;&#x4E2A;&#x5206;&#x7247;&#x4E2D;</a></li><li><a href="#&#x4E3B;&#x5206;&#x7247;&#x548C;&#x526F;&#x672C;&#x5206;&#x7247;&#x5982;&#x4F55;&#x4EA4;&#x4E92;">&#x4E3B;&#x5206;&#x7247;&#x548C;&#x526F;&#x672C;&#x5206;&#x7247;&#x5982;&#x4F55;&#x4EA4;&#x4E92;</a></li><li><a href="#&#x65B0;&#x5EFA;&#x7D22;&#x5F15;&#x548C;&#x5220;&#x9664;&#x6587;&#x6863;">&#x65B0;&#x5EFA;&#x3001;&#x7D22;&#x5F15;&#x548C;&#x5220;&#x9664;&#x6587;&#x6863;  </a></li><li><a href="#&#x53D6;&#x56DE;&#x4E00;&#x4E2A;&#x6587;&#x6863;">&#x53D6;&#x56DE;&#x4E00;&#x4E2A;&#x6587;&#x6863;</a></li><li><a href="#&#x5C40;&#x90E8;&#x66F4;&#x65B0;&#x6587;&#x6863;">&#x5C40;&#x90E8;&#x66F4;&#x65B0;&#x6587;&#x6863;</a></li><li><a href="#&#x591A;&#x6587;&#x6863;&#x6A21;&#x5F0F;">&#x591A;&#x6587;&#x6863;&#x6A21;&#x5F0F;</a></li></ul><li><a href="#&#x641C;&#x7D22;&#x6700;&#x57FA;&#x672C;&#x7684;&#x5DE5;&#x5177;">&#x641C;&#x7D22;&#x2014;&#x2014;&#x6700;&#x57FA;&#x672C;&#x7684;&#x5DE5;&#x5177;  </a></li><ul><li><a href="#&#x7A7A;&#x641C;&#x7D22;">&#x7A7A;&#x641C;&#x7D22;</a></li><li><a href="#&#x591A;&#x7D22;&#x5F15;&#x591A;&#x7C7B;&#x578B;">&#x591A;&#x7D22;&#x5F15;&#xFF0C;&#x591A;&#x7C7B;&#x578B;  </a></li><li><a href="#&#x5206;&#x9875;">&#x5206;&#x9875;</a></li><li><a href="#&#x8F7B;&#x91CF;&#x641C;&#x7D22;">&#x8F7B;&#x91CF;&#x641C;&#x7D22;</a></li></ul><li><a href="#&#x6620;&#x5C04;&#x548C;&#x5206;&#x6790;">&#x6620;&#x5C04;&#x548C;&#x5206;&#x6790;</a></li><ul><li><a href="#&#x7CBE;&#x786E;&#x503C;VS&#x5168;&#x6587;">&#x7CBE;&#x786E;&#x503C; VS &#x5168;&#x6587;  </a></li><li><a href="#&#x5012;&#x6392;&#x7D22;&#x5F15;">&#x5012;&#x6392;&#x7D22;&#x5F15;</a></li><li><a href="#&#x5206;&#x6790;&#x4E0E;&#x5206;&#x6790;&#x5668;">&#x5206;&#x6790;&#x4E0E;&#x5206;&#x6790;&#x5668;</a></li><li><a href="#&#x6620;&#x5C04;">&#x6620;&#x5C04;</a></li><li><a href="#&#x590D;&#x6742;&#x6838;&#x5FC3;&#x57DF;&#x7C7B;&#x578B;">&#x590D;&#x6742;&#x6838;&#x5FC3;&#x57DF;&#x7C7B;&#x578B;</a></li></ul></ul></ul></div><a href="#&#x57FA;&#x7840;&#x5165;&#x95E8;" id="anchorNavigationExGoTop"><i class="fa fa-arrow-up"></i></a><h1 id="&#x57FA;&#x7840;&#x5165;&#x95E8;"><a name="&#x57FA;&#x7840;&#x5165;&#x95E8;" class="anchor-navigation-ex-anchor" href="#&#x57FA;&#x7840;&#x5165;&#x95E8;"><i class="fa fa-link" aria-hidden="true"></i></a>&#x57FA;&#x7840;&#x5165;&#x95E8;</h1>
<h2 id="&#x5206;&#x5E03;&#x5F0F;&#x6587;&#x6863;&#x5B58;&#x50A8;"><a name="&#x5206;&#x5E03;&#x5F0F;&#x6587;&#x6863;&#x5B58;&#x50A8;" class="anchor-navigation-ex-anchor" href="#&#x5206;&#x5E03;&#x5F0F;&#x6587;&#x6863;&#x5B58;&#x50A8;"><i class="fa fa-link" aria-hidden="true"></i></a>&#x5206;&#x5E03;&#x5F0F;&#x6587;&#x6863;&#x5B58;&#x50A8;</h2>
<p>&#x5728;&#x524D;&#x9762;&#x7684;&#x7AE0;&#x8282;&#xFF0C;&#x6211;&#x4EEC;&#x4ECB;&#x7ECD;&#x4E86;&#x5982;&#x4F55;&#x7D22;&#x5F15;&#x548C;&#x67E5;&#x8BE2;&#x6570;&#x636E;&#xFF0C;&#x4E0D;&#x8FC7;&#x6211;&#x4EEC;&#x5FFD;&#x7565;&#x4E86;&#x5F88;&#x591A;&#x5E95;&#x5C42;&#x7684;&#x6280;&#x672F;&#x7EC6;&#x8282;&#xFF0C; &#x4F8B;&#x5982;&#x6587;&#x4EF6;&#x662F;&#x5982;&#x4F55;&#x5206;&#x5E03;&#x5230;&#x96C6;&#x7FA4;&#x7684;&#xFF0C;&#x53C8;&#x662F;&#x5982;&#x4F55;&#x4ECE;&#x96C6;&#x7FA4;&#x4E2D;&#x83B7;&#x53D6;&#x7684;&#x3002; Elasticsearch &#x672C;&#x610F;&#x5C31;&#x662F;&#x9690;&#x85CF;&#x8FD9;&#x4E9B;&#x5E95;&#x5C42;&#x7EC6;&#x8282;&#xFF0C;&#x8BA9;&#x6211;&#x4EEC;&#x597D;&#x4E13;&#x6CE8;&#x5728;&#x4E1A;&#x52A1;&#x5F00;&#x53D1;&#x4E2D;&#xFF0C;&#x6240;&#x4EE5;&#x5176;&#x5B9E;&#x4F60;&#x4E0D;&#x5FC5;&#x4E86;&#x89E3;&#x8FD9;&#x4E48;&#x6DF1;&#x5165;&#x4E5F;&#x65E0;&#x59A8;&#x3002;</p>
<p>&#x5728;&#x8FD9;&#x4E2A;&#x7AE0;&#x8282;&#x4E2D;&#xFF0C;&#x6211;&#x4EEC;&#x5C06;&#x6DF1;&#x5165;&#x63A2;&#x7D22;&#x8FD9;&#x4E9B;&#x6838;&#x5FC3;&#x7684;&#x6280;&#x672F;&#x7EC6;&#x8282;&#xFF0C;&#x8FD9;&#x80FD;&#x5E2E;&#x52A9;&#x4F60;&#x66F4;&#x597D;&#x5730;&#x7406;&#x89E3;&#x6570;&#x636E;&#x5982;&#x4F55;&#x88AB;&#x5B58;&#x50A8;&#x5230;&#x8FD9;&#x4E2A;&#x5206;&#x5E03;&#x5F0F;&#x7CFB;&#x7EDF;&#x4E2D;&#x3002;</p>
<hr>
<blockquote>
<p> <strong>&#x6CE8;&#x610F;</strong></p>
<p> &#x8FD9;&#x4E2A;&#x7AE0;&#x8282;&#x5305;&#x542B;&#x4E86;&#x4E00;&#x4E9B;&#x9AD8;&#x7EA7;&#x8BDD;&#x9898;&#xFF0C;&#x4E0A;&#x9762;&#x4E5F;&#x63D0;&#x5230;&#x8FC7;&#xFF0C;&#x5C31;&#x7B97;&#x4F60;&#x4E0D;&#x8BB0;&#x4F4F;&#x548C;&#x7406;&#x89E3;&#x6240;&#x6709;&#x7684;&#x7EC6;&#x8282;&#x4ECD;&#x7136;&#x80FD;&#x6B63;&#x5E38;&#x4F7F;&#x7528; &gt;  Elasticsearch&#x3002; &#x5982;&#x679C;&#x4F60;&#x6709;&#x5174;&#x8DA3;&#x7684;&#x8BDD;&#xFF0C;&#x8FD9;&#x4E2A;&#x7AE0;&#x8282;&#x53EF;&#x4EE5;&#x4F5C;&#x4E3A;&#x4F60;&#x7684;&#x8BFE;&#x5916;&#x5174;&#x8DA3;&#x8BFB;&#x7269;&#xFF0C;&#x6269;&#x5C55;&#x4F60;&#x7684;&#x77E5;&#x8BC6;&#x9762;&#x3002;</p>
<p> &#x5982;&#x679C;&#x4F60;&#x5728;&#x9605;&#x8BFB;&#x8FD9;&#x4E2A;&#x7AE0;&#x8282;&#x7684;&#x65F6;&#x5019;&#x611F;&#x5230;&#x5F88;&#x5403;&#x529B;&#xFF0C;&#x4E5F;&#x4E0D;&#x7528;&#x62C5;&#x5FC3;&#x3002; &#x8FD9;&#x4E2A;&#x7AE0;&#x8282;&#x4EC5;&#x4EC5;&#x53EA;&#x662F;&#x7528;&#x6765;&#x544A;&#x8BC9;&#x4F60; Elasticsearch &#x662F;&#x5982;&#x4F55;&#x5DE5;&#x4F5C;&#x7684;&#xFF0C; &#x5C06;&#x6765;&#x5728;&#x5DE5;&#x4F5C;&#x4E2D;&#x5982;&#x679C;&#x4F60;&#x9700;&#x8981;&#x7528;&#x5230;&#x8FD9;&#x4E2A;&#x7AE0;&#x8282;&#x63D0;&#x4F9B;&#x7684;&#x77E5;&#x8BC6;&#xFF0C;&#x53EF;&#x4EE5;&#x518D;&#x56DE;&#x8FC7;&#x5934;&#x6765;&#x7FFB;&#x9605;&#x3002;</p>
</blockquote>
<hr>
<h3 id="&#x8DEF;&#x7531;&#x4E00;&#x4E2A;&#x6587;&#x6863;&#x5230;&#x4E00;&#x4E2A;&#x5206;&#x7247;&#x4E2D;"><a name="&#x8DEF;&#x7531;&#x4E00;&#x4E2A;&#x6587;&#x6863;&#x5230;&#x4E00;&#x4E2A;&#x5206;&#x7247;&#x4E2D;" class="anchor-navigation-ex-anchor" href="#&#x8DEF;&#x7531;&#x4E00;&#x4E2A;&#x6587;&#x6863;&#x5230;&#x4E00;&#x4E2A;&#x5206;&#x7247;&#x4E2D;"><i class="fa fa-link" aria-hidden="true"></i></a>&#x8DEF;&#x7531;&#x4E00;&#x4E2A;&#x6587;&#x6863;&#x5230;&#x4E00;&#x4E2A;&#x5206;&#x7247;&#x4E2D;</h3>
<p>&#x5F53;&#x7D22;&#x5F15;&#x4E00;&#x4E2A;&#x6587;&#x6863;&#x7684;&#x65F6;&#x5019;&#xFF0C;&#x6587;&#x6863;&#x4F1A;&#x88AB;&#x5B58;&#x50A8;&#x5230;&#x4E00;&#x4E2A;&#x4E3B;&#x5206;&#x7247;&#x4E2D;&#x3002; Elasticsearch &#x5982;&#x4F55;&#x77E5;&#x9053;&#x4E00;&#x4E2A;&#x6587;&#x6863;&#x5E94;&#x8BE5;&#x5B58;&#x653E;&#x5230;&#x54EA;&#x4E2A;&#x5206;&#x7247;&#x4E2D;&#x5462;&#xFF1F;&#x5F53;&#x6211;&#x4EEC;&#x521B;&#x5EFA;&#x6587;&#x6863;&#x65F6;&#xFF0C;&#x5B83;&#x5982;&#x4F55;&#x51B3;&#x5B9A;&#x8FD9;&#x4E2A;&#x6587;&#x6863;&#x5E94;&#x5F53;&#x88AB;&#x5B58;&#x50A8;&#x5728;&#x5206;&#x7247; <code>1</code> &#x8FD8;&#x662F;&#x5206;&#x7247; <code>2</code> &#x4E2D;&#x5462;&#xFF1F;</p>
<p>&#x9996;&#x5148;&#x8FD9;&#x80AF;&#x5B9A;&#x4E0D;&#x4F1A;&#x662F;&#x968F;&#x673A;&#x7684;&#xFF0C;&#x5426;&#x5219;&#x5C06;&#x6765;&#x8981;&#x83B7;&#x53D6;&#x6587;&#x6863;&#x7684;&#x65F6;&#x5019;&#x6211;&#x4EEC;&#x5C31;&#x4E0D;&#x77E5;&#x9053;&#x4ECE;&#x4F55;&#x5904;&#x5BFB;&#x627E;&#x4E86;&#x3002;&#x5B9E;&#x9645;&#x4E0A;&#xFF0C;&#x8FD9;&#x4E2A;&#x8FC7;&#x7A0B;&#x662F;&#x6839;&#x636E;&#x4E0B;&#x9762;&#x8FD9;&#x4E2A;&#x516C;&#x5F0F;&#x51B3;&#x5B9A;&#x7684;&#xFF1A;</p>
<pre><code>shard = hash(routing) % number_of_primary_shards
</code></pre><p><code>routing</code> &#x662F;&#x4E00;&#x4E2A;&#x53EF;&#x53D8;&#x503C;&#xFF0C;&#x9ED8;&#x8BA4;&#x662F;&#x6587;&#x6863;&#x7684; <code>_id</code> &#xFF0C;&#x4E5F;&#x53EF;&#x4EE5;&#x8BBE;&#x7F6E;&#x6210;&#x4E00;&#x4E2A;&#x81EA;&#x5B9A;&#x4E49;&#x7684;&#x503C;&#x3002; <code>routing</code> &#x901A;&#x8FC7; hash &#x51FD;&#x6570;&#x751F;&#x6210;&#x4E00;&#x4E2A;&#x6570;&#x5B57;&#xFF0C;&#x7136;&#x540E;&#x8FD9;&#x4E2A;&#x6570;&#x5B57;&#x518D;&#x9664;&#x4EE5; <code>number_of_primary_shards</code> &#xFF08;&#x4E3B;&#x5206;&#x7247;&#x7684;&#x6570;&#x91CF;&#xFF09;&#x540E;&#x5F97;&#x5230; <strong>&#x4F59;&#x6570;</strong> &#x3002;&#x8FD9;&#x4E2A;&#x5206;&#x5E03;&#x5728; <code>0</code> &#x5230; <code>number_of_primary_shards-1</code> &#x4E4B;&#x95F4;&#x7684;&#x4F59;&#x6570;&#xFF0C;&#x5C31;&#x662F;&#x6211;&#x4EEC;&#x6240;&#x5BFB;&#x6C42;&#x7684;&#x6587;&#x6863;&#x6240;&#x5728;&#x5206;&#x7247;&#x7684;&#x4F4D;&#x7F6E;&#x3002;</p>
<p>&#x8FD9;&#x5C31;&#x89E3;&#x91CA;&#x4E86;&#x4E3A;&#x4EC0;&#x4E48;&#x6211;&#x4EEC;&#x8981;&#x5728;&#x521B;&#x5EFA;&#x7D22;&#x5F15;&#x7684;&#x65F6;&#x5019;&#x5C31;&#x786E;&#x5B9A;&#x597D;&#x4E3B;&#x5206;&#x7247;&#x7684;&#x6570;&#x91CF; &#x5E76;&#x4E14;&#x6C38;&#x8FDC;&#x4E0D;&#x4F1A;&#x6539;&#x53D8;&#x8FD9;&#x4E2A;&#x6570;&#x91CF;&#xFF1A;&#x56E0;&#x4E3A;&#x5982;&#x679C;&#x6570;&#x91CF;&#x53D8;&#x5316;&#x4E86;&#xFF0C;&#x90A3;&#x4E48;&#x6240;&#x6709;&#x4E4B;&#x524D;&#x8DEF;&#x7531;&#x7684;&#x503C;&#x90FD;&#x4F1A;&#x65E0;&#x6548;&#xFF0C;&#x6587;&#x6863;&#x4E5F;&#x518D;&#x4E5F;&#x627E;&#x4E0D;&#x5230;&#x4E86;&#x3002;</p>
<blockquote>
<p> <img src="assets/note.png" alt="&#x6CE8;&#x610F;">  &#x4F60;&#x53EF;&#x80FD;&#x89C9;&#x5F97;&#x7531;&#x4E8E; Elasticsearch &#x4E3B;&#x5206;&#x7247;&#x6570;&#x91CF;&#x662F;&#x56FA;&#x5B9A;&#x7684;&#x4F1A;&#x4F7F;&#x7D22;&#x5F15;&#x96BE;&#x4EE5;&#x8FDB;&#x884C;&#x6269;&#x5BB9;&#x3002;&#x5B9E;&#x9645;&#x4E0A;&#x5F53;&#x4F60;&#x9700;&#x8981;&#x65F6;&#x6709;&#x5F88;&#x591A;&#x6280;&#x5DE7;&#x53EF;&#x4EE5;&#x8F7B;&#x677E;&#x5B9E;&#x73B0;&#x6269;&#x5BB9;&#x3002;&#x6211;&#x4EEC;&#x5C06;&#x4F1A;&#x5728;<a href="https://www.elastic.co/guide/cn/elasticsearch/guide/current/scale.html" target="_blank"><em>&#x6269;&#x5BB9;&#x8BBE;&#x8BA1;</em></a>&#x4E00;&#x7AE0;&#x4E2D;&#x63D0;&#x5230;&#x66F4;&#x591A;&#x6709;&#x5173;&#x6C34;&#x5E73;&#x6269;&#x5C55;&#x7684;&#x5185;&#x5BB9;&#x3002;</p>
</blockquote>
<p>&#x6240;&#x6709;&#x7684;&#x6587;&#x6863; API&#xFF08; <code>get</code> &#x3001; <code>index</code> &#x3001; <code>delete</code> &#x3001; <code>bulk</code> &#x3001; <code>update</code> &#x4EE5;&#x53CA; <code>mget</code> &#xFF09;&#x90FD;&#x63A5;&#x53D7;&#x4E00;&#x4E2A;&#x53EB;&#x505A; <code>routing</code>&#x7684;&#x8DEF;&#x7531;&#x53C2;&#x6570; &#xFF0C;&#x901A;&#x8FC7;&#x8FD9;&#x4E2A;&#x53C2;&#x6570;&#x6211;&#x4EEC;&#x53EF;&#x4EE5;&#x81EA;&#x5B9A;&#x4E49;&#x6587;&#x6863;&#x5230;&#x5206;&#x7247;&#x7684;&#x6620;&#x5C04;&#x3002;&#x4E00;&#x4E2A;&#x81EA;&#x5B9A;&#x4E49;&#x7684;&#x8DEF;&#x7531;&#x53C2;&#x6570;&#x53EF;&#x4EE5;&#x7528;&#x6765;&#x786E;&#x4FDD;&#x6240;&#x6709;&#x76F8;&#x5173;&#x7684;&#x6587;&#x6863;&#x2014;&#x2014;&#x4F8B;&#x5982;&#x6240;&#x6709;&#x5C5E;&#x4E8E;&#x540C;&#x4E00;&#x4E2A;&#x7528;&#x6237;&#x7684;&#x6587;&#x6863;&#x2014;&#x2014;&#x90FD;&#x88AB;&#x5B58;&#x50A8;&#x5230;&#x540C;&#x4E00;&#x4E2A;&#x5206;&#x7247;&#x4E2D;&#x3002;&#x6211;&#x4EEC;&#x4E5F;&#x4F1A;&#x5728;<a href="https://www.elastic.co/guide/cn/elasticsearch/guide/current/scale.html" target="_blank"><em>&#x6269;&#x5BB9;&#x8BBE;&#x8BA1;</em></a>&#x8FD9;&#x4E00;&#x7AE0;&#x4E2D;&#x8BE6;&#x7EC6;&#x8BA8;&#x8BBA;&#x4E3A;&#x4EC0;&#x4E48;&#x4F1A;&#x6709;&#x8FD9;&#x6837;&#x4E00;&#x79CD;&#x9700;&#x6C42;&#x3002;</p>
<h3 id="&#x4E3B;&#x5206;&#x7247;&#x548C;&#x526F;&#x672C;&#x5206;&#x7247;&#x5982;&#x4F55;&#x4EA4;&#x4E92;"><a name="&#x4E3B;&#x5206;&#x7247;&#x548C;&#x526F;&#x672C;&#x5206;&#x7247;&#x5982;&#x4F55;&#x4EA4;&#x4E92;" class="anchor-navigation-ex-anchor" href="#&#x4E3B;&#x5206;&#x7247;&#x548C;&#x526F;&#x672C;&#x5206;&#x7247;&#x5982;&#x4F55;&#x4EA4;&#x4E92;"><i class="fa fa-link" aria-hidden="true"></i></a>&#x4E3B;&#x5206;&#x7247;&#x548C;&#x526F;&#x672C;&#x5206;&#x7247;&#x5982;&#x4F55;&#x4EA4;&#x4E92;</h3>
<p>&#x4E3A;&#x4E86;&#x8BF4;&#x660E;&#x76EE;&#x7684;, &#x6211;&#x4EEC; &#x5047;&#x8BBE;&#x6709;&#x4E00;&#x4E2A;&#x96C6;&#x7FA4;&#x7531;&#x4E09;&#x4E2A;&#x8282;&#x70B9;&#x7EC4;&#x6210;&#x3002; &#x5B83;&#x5305;&#x542B;&#x4E00;&#x4E2A;&#x53EB; <code>blogs</code> &#x7684;&#x7D22;&#x5F15;&#xFF0C;&#x6709;&#x4E24;&#x4E2A;&#x4E3B;&#x5206;&#x7247;&#xFF0C;&#x6BCF;&#x4E2A;&#x4E3B;&#x5206;&#x7247;&#x6709;&#x4E24;&#x4E2A;&#x526F;&#x672C;&#x5206;&#x7247;&#x3002;&#x76F8;&#x540C;&#x5206;&#x7247;&#x7684;&#x526F;&#x672C;&#x4E0D;&#x4F1A;&#x653E;&#x5728;&#x540C;&#x4E00;&#x8282;&#x70B9;&#xFF0C;&#x6240;&#x4EE5;&#x6211;&#x4EEC;&#x7684;&#x96C6;&#x7FA4;&#x770B;&#x8D77;&#x6765;&#x50CF; <a href="https://www.elastic.co/guide/cn/elasticsearch/guide/current/how-primary-and-replica-shards-interact.html#img-distrib" target="_blank">&#x56FE; 8 &#x201C;&#x6709;&#x4E09;&#x4E2A;&#x8282;&#x70B9;&#x548C;&#x4E00;&#x4E2A;&#x7D22;&#x5F15;&#x7684;&#x96C6;&#x7FA4;&#x201D;</a>&#x3002;</p>
<p><strong>&#x56FE; 8. &#x6709;&#x4E09;&#x4E2A;&#x8282;&#x70B9;&#x548C;&#x4E00;&#x4E2A;&#x7D22;&#x5F15;&#x7684;&#x96C6;&#x7FA4;</strong></p>
<p><img src="assets/elas_0401.png" alt="&#x6709;&#x4E09;&#x4E2A;&#x8282;&#x70B9;&#x548C;&#x4E00;&#x4E2A;&#x7D22;&#x5F15;&#x7684;&#x96C6;&#x7FA4;"></p>
<p>&#x6211;&#x4EEC;&#x53EF;&#x4EE5;&#x53D1;&#x9001;&#x8BF7;&#x6C42;&#x5230;&#x96C6;&#x7FA4;&#x4E2D;&#x7684;&#x4EFB;&#x4E00;&#x8282;&#x70B9;&#x3002; &#x6BCF;&#x4E2A;&#x8282;&#x70B9;&#x90FD;&#x6709;&#x80FD;&#x529B;&#x5904;&#x7406;&#x4EFB;&#x610F;&#x8BF7;&#x6C42;&#x3002; &#x6BCF;&#x4E2A;&#x8282;&#x70B9;&#x90FD;&#x77E5;&#x9053;&#x96C6;&#x7FA4;&#x4E2D;&#x4EFB;&#x4E00;&#x6587;&#x6863;&#x4F4D;&#x7F6E;&#xFF0C;&#x6240;&#x4EE5;&#x53EF;&#x4EE5;&#x76F4;&#x63A5;&#x5C06;&#x8BF7;&#x6C42;&#x8F6C;&#x53D1;&#x5230;&#x9700;&#x8981;&#x7684;&#x8282;&#x70B9;&#x4E0A;&#x3002; &#x5728;&#x4E0B;&#x9762;&#x7684;&#x4F8B;&#x5B50;&#x4E2D;&#xFF0C;&#x5C06;&#x6240;&#x6709;&#x7684;&#x8BF7;&#x6C42;&#x53D1;&#x9001;&#x5230; <code>Node 1</code> &#xFF0C;&#x6211;&#x4EEC;&#x5C06;&#x5176;&#x79F0;&#x4E3A; <em>&#x534F;&#x8C03;&#x8282;&#x70B9;(coordinating node)</em> &#x3002;</p>
<blockquote>
<p> <img src="assets/tip.png" alt="&#x63D0;&#x793A;">  &#x5F53;&#x53D1;&#x9001;&#x8BF7;&#x6C42;&#x7684;&#x65F6;&#x5019;&#xFF0C; &#x4E3A;&#x4E86;&#x6269;&#x5C55;&#x8D1F;&#x8F7D;&#xFF0C;&#x66F4;&#x597D;&#x7684;&#x505A;&#x6CD5;&#x662F;&#x8F6E;&#x8BE2;&#x96C6;&#x7FA4;&#x4E2D;&#x6240;&#x6709;&#x7684;&#x8282;&#x70B9;&#x3002;</p>
</blockquote>
<h3 id="&#x65B0;&#x5EFA;&#x7D22;&#x5F15;&#x548C;&#x5220;&#x9664;&#x6587;&#x6863;"><a name="&#x65B0;&#x5EFA;&#x7D22;&#x5F15;&#x548C;&#x5220;&#x9664;&#x6587;&#x6863;" class="anchor-navigation-ex-anchor" href="#&#x65B0;&#x5EFA;&#x7D22;&#x5F15;&#x548C;&#x5220;&#x9664;&#x6587;&#x6863;"><i class="fa fa-link" aria-hidden="true"></i></a>&#x65B0;&#x5EFA;&#x3001;&#x7D22;&#x5F15;&#x548C;&#x5220;&#x9664;&#x6587;&#x6863;  </h3>
<p>&#x65B0;&#x5EFA;&#x3001;&#x7D22;&#x5F15;&#x548C;&#x5220;&#x9664; &#x8BF7;&#x6C42;&#x90FD;&#x662F; <em>&#x5199;</em> &#x64CD;&#x4F5C;&#xFF0C; &#x5FC5;&#x987B;&#x5728;&#x4E3B;&#x5206;&#x7247;&#x4E0A;&#x9762;&#x5B8C;&#x6210;&#x4E4B;&#x540E;&#x624D;&#x80FD;&#x88AB;&#x590D;&#x5236;&#x5230;&#x76F8;&#x5173;&#x7684;&#x526F;&#x672C;&#x5206;&#x7247;&#xFF0C;&#x5982;&#x4E0B;&#x56FE;&#x6240;&#x793A; <a href="https://www.elastic.co/guide/cn/elasticsearch/guide/current/distrib-write.html#img-distrib-write" target="_blank">&#x56FE; 9 &#x201C;&#x65B0;&#x5EFA;&#x3001;&#x7D22;&#x5F15;&#x548C;&#x5220;&#x9664;&#x5355;&#x4E2A;&#x6587;&#x6863;&#x201D;</a>.</p>
<p><strong>&#x56FE; 9. &#x65B0;&#x5EFA;&#x3001;&#x7D22;&#x5F15;&#x548C;&#x5220;&#x9664;&#x5355;&#x4E2A;&#x6587;&#x6863;</strong></p>
<p><img src="assets/elas_0402.png" alt="&#x65B0;&#x5EFA;&#x3001;&#x7D22;&#x5F15;&#x548C;&#x5220;&#x9664;&#x5355;&#x4E2A;&#x6587;&#x6863;"></p>
<p>&#x4EE5;&#x4E0B;&#x662F;&#x5728;&#x4E3B;&#x526F;&#x5206;&#x7247;&#x548C;&#x4EFB;&#x4F55;&#x526F;&#x672C;&#x5206;&#x7247;&#x4E0A;&#x9762; &#x6210;&#x529F;&#x65B0;&#x5EFA;&#xFF0C;&#x7D22;&#x5F15;&#x548C;&#x5220;&#x9664;&#x6587;&#x6863;&#x6240;&#x9700;&#x8981;&#x7684;&#x6B65;&#x9AA4;&#x987A;&#x5E8F;&#xFF1A;</p>
<ol>
<li>&#x5BA2;&#x6237;&#x7AEF;&#x5411; <code>Node 1</code> &#x53D1;&#x9001;&#x65B0;&#x5EFA;&#x3001;&#x7D22;&#x5F15;&#x6216;&#x8005;&#x5220;&#x9664;&#x8BF7;&#x6C42;&#x3002;</li>
<li>&#x8282;&#x70B9;&#x4F7F;&#x7528;&#x6587;&#x6863;&#x7684; <code>_id</code> &#x786E;&#x5B9A;&#x6587;&#x6863;&#x5C5E;&#x4E8E;&#x5206;&#x7247; 0 &#x3002;&#x8BF7;&#x6C42;&#x4F1A;&#x88AB;&#x8F6C;&#x53D1;&#x5230; <code>Node 3</code>&#xFF0C;&#x56E0;&#x4E3A;&#x5206;&#x7247; 0 &#x7684;&#x4E3B;&#x5206;&#x7247;&#x76EE;&#x524D;&#x88AB;&#x5206;&#x914D;&#x5728; <code>Node 3</code> &#x4E0A;&#x3002;</li>
<li><code>Node 3</code> &#x5728;&#x4E3B;&#x5206;&#x7247;&#x4E0A;&#x9762;&#x6267;&#x884C;&#x8BF7;&#x6C42;&#x3002;&#x5982;&#x679C;&#x6210;&#x529F;&#x4E86;&#xFF0C;&#x5B83;&#x5C06;&#x8BF7;&#x6C42;&#x5E76;&#x884C;&#x8F6C;&#x53D1;&#x5230; <code>Node 1</code> &#x548C; <code>Node 2</code> &#x7684;&#x526F;&#x672C;&#x5206;&#x7247;&#x4E0A;&#x3002;&#x4E00;&#x65E6;&#x6240;&#x6709;&#x7684;&#x526F;&#x672C;&#x5206;&#x7247;&#x90FD;&#x62A5;&#x544A;&#x6210;&#x529F;, <code>Node 3</code> &#x5C06;&#x5411;&#x534F;&#x8C03;&#x8282;&#x70B9;&#x62A5;&#x544A;&#x6210;&#x529F;&#xFF0C;&#x534F;&#x8C03;&#x8282;&#x70B9;&#x5411;&#x5BA2;&#x6237;&#x7AEF;&#x62A5;&#x544A;&#x6210;&#x529F;&#x3002;</li>
</ol>
<p>&#x5728;&#x5BA2;&#x6237;&#x7AEF;&#x6536;&#x5230;&#x6210;&#x529F;&#x54CD;&#x5E94;&#x65F6;&#xFF0C;&#x6587;&#x6863;&#x53D8;&#x66F4;&#x5DF2;&#x7ECF;&#x5728;&#x4E3B;&#x5206;&#x7247;&#x548C;&#x6240;&#x6709;&#x526F;&#x672C;&#x5206;&#x7247;&#x6267;&#x884C;&#x5B8C;&#x6210;&#xFF0C;&#x53D8;&#x66F4;&#x662F;&#x5B89;&#x5168;&#x7684;&#x3002;</p>
<p>&#x6709;&#x4E00;&#x4E9B;&#x53EF;&#x9009;&#x7684;&#x8BF7;&#x6C42;&#x53C2;&#x6570;&#x5141;&#x8BB8;&#x60A8;&#x5F71;&#x54CD;&#x8FD9;&#x4E2A;&#x8FC7;&#x7A0B;&#xFF0C;&#x53EF;&#x80FD;&#x4EE5;&#x6570;&#x636E;&#x5B89;&#x5168;&#x4E3A;&#x4EE3;&#x4EF7;&#x63D0;&#x5347;&#x6027;&#x80FD;&#x3002;&#x8FD9;&#x4E9B;&#x9009;&#x9879;&#x5F88;&#x5C11;&#x4F7F;&#x7528;&#xFF0C;&#x56E0;&#x4E3A;Elasticsearch&#x5DF2;&#x7ECF;&#x5F88;&#x5FEB;&#xFF0C;&#x4F46;&#x662F;&#x4E3A;&#x4E86;&#x5B8C;&#x6574;&#x8D77;&#x89C1;&#xFF0C;&#x5728;&#x8FD9;&#x91CC;&#x9610;&#x8FF0;&#x5982;&#x4E0B;&#xFF1A;</p>
<ul>
<li><p><code>consistency</code></p>
<p>consistency&#xFF0C;&#x5373;&#x4E00;&#x81F4;&#x6027;&#x3002;&#x5728;&#x9ED8;&#x8BA4;&#x8BBE;&#x7F6E;&#x4E0B;&#xFF0C;&#x5373;&#x4F7F;&#x4EC5;&#x4EC5;&#x662F;&#x5728;&#x8BD5;&#x56FE;&#x6267;&#x884C;&#x4E00;&#x4E2A;<em>&#x5199;</em>&#x64CD;&#x4F5C;&#x4E4B;&#x524D;&#xFF0C;&#x4E3B;&#x5206;&#x7247;&#x90FD;&#x4F1A;&#x8981;&#x6C42;&#x5FC5;&#x987B;&#x8981;&#x6709; <em>&#x89C4;&#x5B9A;&#x6570;&#x91CF;(quorum)</em>&#xFF08;&#x6216;&#x8005;&#x6362;&#x79CD;&#x8BF4;&#x6CD5;&#xFF0C;&#x4E5F;&#x5373;&#x5FC5;&#x987B;&#x8981;&#x6709;&#x5927;&#x591A;&#x6570;&#xFF09;&#x7684;&#x5206;&#x7247;&#x526F;&#x672C;&#x5904;&#x4E8E;&#x6D3B;&#x8DC3;&#x53EF;&#x7528;&#x72B6;&#x6001;&#xFF0C;&#x624D;&#x4F1A;&#x53BB;&#x6267;&#x884C;<em>&#x5199;</em>&#x64CD;&#x4F5C;(&#x5176;&#x4E2D;&#x5206;&#x7247;&#x526F;&#x672C;&#x53EF;&#x4EE5;&#x662F;&#x4E3B;&#x5206;&#x7247;&#x6216;&#x8005;&#x526F;&#x672C;&#x5206;&#x7247;)&#x3002;&#x8FD9;&#x662F;&#x4E3A;&#x4E86;&#x907F;&#x514D;&#x5728;&#x53D1;&#x751F;&#x7F51;&#x7EDC;&#x5206;&#x533A;&#x6545;&#x969C;&#xFF08;network partition&#xFF09;&#x7684;&#x65F6;&#x5019;&#x8FDB;&#x884C;<em>&#x5199;</em>&#x64CD;&#x4F5C;&#xFF0C;&#x8FDB;&#x800C;&#x5BFC;&#x81F4;&#x6570;&#x636E;&#x4E0D;&#x4E00;&#x81F4;&#x3002;<em>&#x89C4;&#x5B9A;&#x6570;&#x91CF;</em>&#x5373;&#xFF1A;<code>int( (primary + number_of_replicas) / 2 ) + 1``consistency</code> &#x53C2;&#x6570;&#x7684;&#x503C;&#x53EF;&#x4EE5;&#x8BBE;&#x4E3A; <code>one</code> &#xFF08;&#x53EA;&#x8981;&#x4E3B;&#x5206;&#x7247;&#x72B6;&#x6001; ok &#x5C31;&#x5141;&#x8BB8;&#x6267;&#x884C;<em>&#x5199;</em>&#x64CD;&#x4F5C;&#xFF09;,<code>all</code>&#xFF08;&#x5FC5;&#x987B;&#x8981;&#x4E3B;&#x5206;&#x7247;&#x548C;&#x6240;&#x6709;&#x526F;&#x672C;&#x5206;&#x7247;&#x7684;&#x72B6;&#x6001;&#x6CA1;&#x95EE;&#x9898;&#x624D;&#x5141;&#x8BB8;&#x6267;&#x884C;<em>&#x5199;</em>&#x64CD;&#x4F5C;&#xFF09;, &#x6216; <code>quorum</code> &#x3002;&#x9ED8;&#x8BA4;&#x503C;&#x4E3A; <code>quorum</code> , &#x5373;&#x5927;&#x591A;&#x6570;&#x7684;&#x5206;&#x7247;&#x526F;&#x672C;&#x72B6;&#x6001;&#x6CA1;&#x95EE;&#x9898;&#x5C31;&#x5141;&#x8BB8;&#x6267;&#x884C;<em>&#x5199;</em>&#x64CD;&#x4F5C;&#x3002;&#x6CE8;&#x610F;&#xFF0C;<em>&#x89C4;&#x5B9A;&#x6570;&#x91CF;</em> &#x7684;&#x8BA1;&#x7B97;&#x516C;&#x5F0F;&#x4E2D; <code>number_of_replicas</code> &#x6307;&#x7684;&#x662F;&#x5728;&#x7D22;&#x5F15;&#x8BBE;&#x7F6E;&#x4E2D;&#x7684;&#x8BBE;&#x5B9A;&#x526F;&#x672C;&#x5206;&#x7247;&#x6570;&#xFF0C;&#x800C;&#x4E0D;&#x662F;&#x6307;&#x5F53;&#x524D;&#x5904;&#x7406;&#x6D3B;&#x52A8;&#x72B6;&#x6001;&#x7684;&#x526F;&#x672C;&#x5206;&#x7247;&#x6570;&#x3002;&#x5982;&#x679C;&#x4F60;&#x7684;&#x7D22;&#x5F15;&#x8BBE;&#x7F6E;&#x4E2D;&#x6307;&#x5B9A;&#x4E86;&#x5F53;&#x524D;&#x7D22;&#x5F15;&#x62E5;&#x6709;&#x4E09;&#x4E2A;&#x526F;&#x672C;&#x5206;&#x7247;&#xFF0C;&#x90A3;&#x89C4;&#x5B9A;&#x6570;&#x91CF;&#x7684;&#x8BA1;&#x7B97;&#x7ED3;&#x679C;&#x5373;&#xFF1A;<code>int( (primary + 3 replicas) / 2 ) + 1 = 3</code>&#x5982;&#x679C;&#x6B64;&#x65F6;&#x4F60;&#x53EA;&#x542F;&#x52A8;&#x4E24;&#x4E2A;&#x8282;&#x70B9;&#xFF0C;&#x90A3;&#x4E48;&#x5904;&#x4E8E;&#x6D3B;&#x8DC3;&#x72B6;&#x6001;&#x7684;&#x5206;&#x7247;&#x526F;&#x672C;&#x6570;&#x91CF;&#x5C31;&#x8FBE;&#x4E0D;&#x5230;&#x89C4;&#x5B9A;&#x6570;&#x91CF;&#xFF0C;&#x4E5F;&#x56E0;&#x6B64;&#x60A8;&#x5C06;&#x65E0;&#x6CD5;&#x7D22;&#x5F15;&#x548C;&#x5220;&#x9664;&#x4EFB;&#x4F55;&#x6587;&#x6863;&#x3002;</p>
</li>
<li><p><code>timeout</code></p>
<p>&#x5982;&#x679C;&#x6CA1;&#x6709;&#x8DB3;&#x591F;&#x7684;&#x526F;&#x672C;&#x5206;&#x7247;&#x4F1A;&#x53D1;&#x751F;&#x4EC0;&#x4E48;&#xFF1F; Elasticsearch&#x4F1A;&#x7B49;&#x5F85;&#xFF0C;&#x5E0C;&#x671B;&#x66F4;&#x591A;&#x7684;&#x5206;&#x7247;&#x51FA;&#x73B0;&#x3002;&#x9ED8;&#x8BA4;&#x60C5;&#x51B5;&#x4E0B;&#xFF0C;&#x5B83;&#x6700;&#x591A;&#x7B49;&#x5F85;1&#x5206;&#x949F;&#x3002; &#x5982;&#x679C;&#x4F60;&#x9700;&#x8981;&#xFF0C;&#x4F60;&#x53EF;&#x4EE5;&#x4F7F;&#x7528; <code>timeout</code> &#x53C2;&#x6570; &#x4F7F;&#x5B83;&#x66F4;&#x65E9;&#x7EC8;&#x6B62;&#xFF1A; <code>100</code> 100&#x6BEB;&#x79D2;&#xFF0C;<code>30s</code> &#x662F;30&#x79D2;&#x3002;</p>
<blockquote>
<p> <img src="assets/note.png" alt="&#x6CE8;&#x610F;">  &#x65B0;&#x7D22;&#x5F15;&#x9ED8;&#x8BA4;&#x6709; <code>1</code> &#x4E2A;&#x526F;&#x672C;&#x5206;&#x7247;&#xFF0C;&#x8FD9;&#x610F;&#x5473;&#x7740;&#x4E3A;&#x6EE1;&#x8DB3; <code>&#x89C4;&#x5B9A;&#x6570;&#x91CF;</code> <em>&#x5E94;&#x8BE5;</em> &#x9700;&#x8981;&#x4E24;&#x4E2A;&#x6D3B;&#x52A8;&#x7684;&#x5206;&#x7247;&#x526F;&#x672C;&#x3002; &#x4F46;&#x662F;&#xFF0C;&#x8FD9;&#x4E9B;&#x9ED8;&#x8BA4;&#x7684;&#x8BBE;&#x7F6E;&#x4F1A;&#x963B;&#x6B62;&#x6211;&#x4EEC;&#x5728;&#x5355;&#x4E00;&#x8282;&#x70B9;&#x4E0A;&#x505A;&#x4EFB;&#x4F55;&#x4E8B;&#x60C5;&#x3002;&#x4E3A;&#x4E86;&#x907F;&#x514D;&#x8FD9;&#x4E2A;&#x95EE;&#x9898;&#xFF0C;&#x8981;&#x6C42;&#x53EA;&#x6709;&#x5F53; <code>number_of_replicas</code> &#x5927;&#x4E8E;1&#x7684;&#x65F6;&#x5019;&#xFF0C;&#x89C4;&#x5B9A;&#x6570;&#x91CF;&#x624D;&#x4F1A;&#x6267;&#x884C;&#x3002;</p>
</blockquote>
</li>
</ul>
<h3 id="&#x53D6;&#x56DE;&#x4E00;&#x4E2A;&#x6587;&#x6863;"><a name="&#x53D6;&#x56DE;&#x4E00;&#x4E2A;&#x6587;&#x6863;" class="anchor-navigation-ex-anchor" href="#&#x53D6;&#x56DE;&#x4E00;&#x4E2A;&#x6587;&#x6863;"><i class="fa fa-link" aria-hidden="true"></i></a>&#x53D6;&#x56DE;&#x4E00;&#x4E2A;&#x6587;&#x6863;</h3>
<p>&#x53EF;&#x4EE5;&#x4ECE;&#x4E3B;&#x5206;&#x7247;&#x6216;&#x8005;&#x4ECE;&#x5176;&#x5B83;&#x4EFB;&#x610F;&#x526F;&#x672C;&#x5206;&#x7247;&#x68C0;&#x7D22;&#x6587;&#x6863; &#xFF0C;&#x5982;&#x4E0B;&#x56FE;&#x6240;&#x793A; <a href="https://www.elastic.co/guide/cn/elasticsearch/guide/current/distrib-read.html#img-distrib-read" target="_blank">&#x56FE; 10 &#x201C;&#x53D6;&#x56DE;&#x5355;&#x4E2A;&#x6587;&#x6863;&#x201D;</a>.</p>
<p><strong>&#x56FE; 10. &#x53D6;&#x56DE;&#x5355;&#x4E2A;&#x6587;&#x6863;</strong></p>
<p><img src="assets/elas_0403.png" alt="&#x53D6;&#x56DE;&#x5355;&#x4E2A;&#x6587;&#x6863;"></p>
<p>&#x4EE5;&#x4E0B;&#x662F;&#x4ECE;&#x4E3B;&#x5206;&#x7247;&#x6216;&#x8005;&#x526F;&#x672C;&#x5206;&#x7247;&#x68C0;&#x7D22;&#x6587;&#x6863;&#x7684;&#x6B65;&#x9AA4;&#x987A;&#x5E8F;&#xFF1A;</p>
<p>1&#x3001;&#x5BA2;&#x6237;&#x7AEF;&#x5411; <code>Node 1</code> &#x53D1;&#x9001;&#x83B7;&#x53D6;&#x8BF7;&#x6C42;&#x3002;</p>
<p>2&#x3001;&#x8282;&#x70B9;&#x4F7F;&#x7528;&#x6587;&#x6863;&#x7684; <code>_id</code> &#x6765;&#x786E;&#x5B9A;&#x6587;&#x6863;&#x5C5E;&#x4E8E;&#x5206;&#x7247; <code>0</code> &#x3002;&#x5206;&#x7247; <code>0</code> &#x7684;&#x526F;&#x672C;&#x5206;&#x7247;&#x5B58;&#x5728;&#x4E8E;&#x6240;&#x6709;&#x7684;&#x4E09;&#x4E2A;&#x8282;&#x70B9;&#x4E0A;&#x3002; &#x5728;&#x8FD9;&#x79CD;&#x60C5;&#x51B5;&#x4E0B;&#xFF0C;&#x5B83;&#x5C06;&#x8BF7;&#x6C42;&#x8F6C;&#x53D1;&#x5230; <code>Node 2</code> &#x3002;</p>
<p>3&#x3001;<code>Node 2</code> &#x5C06;&#x6587;&#x6863;&#x8FD4;&#x56DE;&#x7ED9; <code>Node 1</code> &#xFF0C;&#x7136;&#x540E;&#x5C06;&#x6587;&#x6863;&#x8FD4;&#x56DE;&#x7ED9;&#x5BA2;&#x6237;&#x7AEF;&#x3002;</p>
<p>&#x5728;&#x5904;&#x7406;&#x8BFB;&#x53D6;&#x8BF7;&#x6C42;&#x65F6;&#xFF0C;&#x534F;&#x8C03;&#x7ED3;&#x70B9;&#x5728;&#x6BCF;&#x6B21;&#x8BF7;&#x6C42;&#x7684;&#x65F6;&#x5019;&#x90FD;&#x4F1A;&#x901A;&#x8FC7;&#x8F6E;&#x8BE2;&#x6240;&#x6709;&#x7684;&#x526F;&#x672C;&#x5206;&#x7247;&#x6765;&#x8FBE;&#x5230;&#x8D1F;&#x8F7D;&#x5747;&#x8861;&#x3002;</p>
<p>&#x5728;&#x6587;&#x6863;&#x88AB;&#x68C0;&#x7D22;&#x65F6;&#xFF0C;&#x5DF2;&#x7ECF;&#x88AB;&#x7D22;&#x5F15;&#x7684;&#x6587;&#x6863;&#x53EF;&#x80FD;&#x5DF2;&#x7ECF;&#x5B58;&#x5728;&#x4E8E;&#x4E3B;&#x5206;&#x7247;&#x4E0A;&#x4F46;&#x662F;&#x8FD8;&#x6CA1;&#x6709;&#x590D;&#x5236;&#x5230;&#x526F;&#x672C;&#x5206;&#x7247;&#x3002; &#x5728;&#x8FD9;&#x79CD;&#x60C5;&#x51B5;&#x4E0B;&#xFF0C;&#x526F;&#x672C;&#x5206;&#x7247;&#x53EF;&#x80FD;&#x4F1A;&#x62A5;&#x544A;&#x6587;&#x6863;&#x4E0D;&#x5B58;&#x5728;&#xFF0C;&#x4F46;&#x662F;&#x4E3B;&#x5206;&#x7247;&#x53EF;&#x80FD;&#x6210;&#x529F;&#x8FD4;&#x56DE;&#x6587;&#x6863;&#x3002; &#x4E00;&#x65E6;&#x7D22;&#x5F15;&#x8BF7;&#x6C42;&#x6210;&#x529F;&#x8FD4;&#x56DE;&#x7ED9;&#x7528;&#x6237;&#xFF0C;&#x6587;&#x6863;&#x5728;&#x4E3B;&#x5206;&#x7247;&#x548C;&#x526F;&#x672C;&#x5206;&#x7247;&#x90FD;&#x662F;&#x53EF;&#x7528;&#x7684;&#x3002;</p>
<h3 id="&#x5C40;&#x90E8;&#x66F4;&#x65B0;&#x6587;&#x6863;"><a name="&#x5C40;&#x90E8;&#x66F4;&#x65B0;&#x6587;&#x6863;" class="anchor-navigation-ex-anchor" href="#&#x5C40;&#x90E8;&#x66F4;&#x65B0;&#x6587;&#x6863;"><i class="fa fa-link" aria-hidden="true"></i></a>&#x5C40;&#x90E8;&#x66F4;&#x65B0;&#x6587;&#x6863;</h3>
<p>&#x5982; <a href="https://www.elastic.co/guide/cn/elasticsearch/guide/current/_partial_updates_to_a_document.html#img-distrib-update" target="_blank">&#x56FE; 11 &#x201C;&#x5C40;&#x90E8;&#x66F4;&#x65B0;&#x6587;&#x6863;&#x201D;</a> &#x6240;&#x793A;&#xFF0C;<code>update</code> API &#x7ED3;&#x5408;&#x4E86;&#x5148;&#x524D;&#x8BF4;&#x660E;&#x7684;&#x8BFB;&#x53D6;&#x548C;&#x5199;&#x5165;&#x6A21;&#x5F0F; &#x3002;</p>
<p><strong>&#x56FE; 11. &#x5C40;&#x90E8;&#x66F4;&#x65B0;&#x6587;&#x6863;</strong></p>
<p><img src="assets/elas_0404.png" alt="&#x5C40;&#x90E8;&#x66F4;&#x65B0;&#x6587;&#x6863;"></p>
<p>&#x4EE5;&#x4E0B;&#x662F;&#x90E8;&#x5206;&#x66F4;&#x65B0;&#x4E00;&#x4E2A;&#x6587;&#x6863;&#x7684;&#x6B65;&#x9AA4;&#xFF1A;</p>
<ol>
<li>&#x5BA2;&#x6237;&#x7AEF;&#x5411; <code>Node 1</code> &#x53D1;&#x9001;&#x66F4;&#x65B0;&#x8BF7;&#x6C42;&#x3002;</li>
<li>&#x5B83;&#x5C06;&#x8BF7;&#x6C42;&#x8F6C;&#x53D1;&#x5230;&#x4E3B;&#x5206;&#x7247;&#x6240;&#x5728;&#x7684; <code>Node 3</code> &#x3002;</li>
<li><code>Node 3</code> &#x4ECE;&#x4E3B;&#x5206;&#x7247;&#x68C0;&#x7D22;&#x6587;&#x6863;&#xFF0C;&#x4FEE;&#x6539; <code>_source</code> &#x5B57;&#x6BB5;&#x4E2D;&#x7684; JSON &#xFF0C;&#x5E76;&#x4E14;&#x5C1D;&#x8BD5;&#x91CD;&#x65B0;&#x7D22;&#x5F15;&#x4E3B;&#x5206;&#x7247;&#x7684;&#x6587;&#x6863;&#x3002; &#x5982;&#x679C;&#x6587;&#x6863;&#x5DF2;&#x7ECF;&#x88AB;&#x53E6;&#x4E00;&#x4E2A;&#x8FDB;&#x7A0B;&#x4FEE;&#x6539;&#xFF0C;&#x5B83;&#x4F1A;&#x91CD;&#x8BD5;&#x6B65;&#x9AA4; 3 &#xFF0C;&#x8D85;&#x8FC7; <code>retry_on_conflict</code> &#x6B21;&#x540E;&#x653E;&#x5F03;&#x3002;</li>
<li>&#x5982;&#x679C; <code>Node 3</code> &#x6210;&#x529F;&#x5730;&#x66F4;&#x65B0;&#x6587;&#x6863;&#xFF0C;&#x5B83;&#x5C06;&#x65B0;&#x7248;&#x672C;&#x7684;&#x6587;&#x6863;&#x5E76;&#x884C;&#x8F6C;&#x53D1;&#x5230; <code>Node 1</code> &#x548C; <code>Node 2</code> &#x4E0A;&#x7684;&#x526F;&#x672C;&#x5206;&#x7247;&#xFF0C;&#x91CD;&#x65B0;&#x5EFA;&#x7ACB;&#x7D22;&#x5F15;&#x3002; &#x4E00;&#x65E6;&#x6240;&#x6709;&#x526F;&#x672C;&#x5206;&#x7247;&#x90FD;&#x8FD4;&#x56DE;&#x6210;&#x529F;&#xFF0C; <code>Node 3</code> &#x5411;&#x534F;&#x8C03;&#x8282;&#x70B9;&#x4E5F;&#x8FD4;&#x56DE;&#x6210;&#x529F;&#xFF0C;&#x534F;&#x8C03;&#x8282;&#x70B9;&#x5411;&#x5BA2;&#x6237;&#x7AEF;&#x8FD4;&#x56DE;&#x6210;&#x529F;&#x3002;</li>
</ol>
<p><code>update</code> API &#x8FD8;&#x63A5;&#x53D7;&#x5728; <a href="https://www.elastic.co/guide/cn/elasticsearch/guide/current/distrib-write.html" target="_blank">&#x65B0;&#x5EFA;&#x3001;&#x7D22;&#x5F15;&#x548C;&#x5220;&#x9664;&#x6587;&#x6863;</a> &#x7AE0;&#x8282;&#x4E2D;&#x4ECB;&#x7ECD;&#x7684; <code>routing</code> &#x3001; <code>replication</code> &#x3001; <code>consistency</code> &#x548C; <code>timeout</code> &#x53C2;&#x6570;&#x3002;</p>
<hr>
<blockquote>
<p> <strong>&#x57FA;&#x4E8E;&#x6587;&#x6863;&#x7684;&#x590D;&#x5236;</strong></p>
<p> &#x5F53;&#x4E3B;&#x5206;&#x7247;&#x628A;&#x66F4;&#x6539;&#x8F6C;&#x53D1;&#x5230;&#x526F;&#x672C;&#x5206;&#x7247;&#x65F6;&#xFF0C; &#x5B83;&#x4E0D;&#x4F1A;&#x8F6C;&#x53D1;&#x66F4;&#x65B0;&#x8BF7;&#x6C42;&#x3002; &#x76F8;&#x53CD;&#xFF0C;&#x5B83;&#x8F6C;&#x53D1;&#x5B8C;&#x6574;&#x6587;&#x6863;&#x7684;&#x65B0;&#x7248;&#x672C;&#x3002;&#x8BF7;&#x8BB0;&#x4F4F;&#xFF0C;&#x8FD9;&#x4E9B;&#x66F4;&#x6539;&#x5C06;&#x4F1A;&#x5F02;&#x6B65;&#x8F6C;&#x53D1;&#x5230;&#x526F;&#x672C;&#x5206;&#x7247;&#xFF0C;&#x5E76;&#x4E14;&#x4E0D;&#x80FD;&#x4FDD;&#x8BC1;&#x5B83;&#x4EEC;&#x4EE5;&#x53D1;&#x9001;&#x5B83;&#x4EEC;&#x76F8;&#x540C;&#x7684;&#x987A;&#x5E8F;&#x5230;&#x8FBE;&#x3002; &#x5982;&#x679C;Elasticsearch&#x4EC5;&#x8F6C;&#x53D1;&#x66F4;&#x6539;&#x8BF7;&#x6C42;&#xFF0C;&#x5219;&#x53EF;&#x80FD;&#x4EE5;&#x9519;&#x8BEF;&#x7684;&#x987A;&#x5E8F;&#x5E94;&#x7528;&#x66F4;&#x6539;&#xFF0C;&#x5BFC;&#x81F4;&#x5F97;&#x5230;&#x635F;&#x574F;&#x7684;&#x6587;&#x6863;&#x3002;</p>
</blockquote>
<hr>
<h3 id="&#x591A;&#x6587;&#x6863;&#x6A21;&#x5F0F;"><a name="&#x591A;&#x6587;&#x6863;&#x6A21;&#x5F0F;" class="anchor-navigation-ex-anchor" href="#&#x591A;&#x6587;&#x6863;&#x6A21;&#x5F0F;"><i class="fa fa-link" aria-hidden="true"></i></a>&#x591A;&#x6587;&#x6863;&#x6A21;&#x5F0F;</h3>
<p><code>mget</code> &#x548C; <code>bulk</code> API &#x7684; &#x6A21;&#x5F0F;&#x7C7B;&#x4F3C;&#x4E8E;&#x5355;&#x6587;&#x6863;&#x6A21;&#x5F0F;&#x3002;&#x533A;&#x522B;&#x5728;&#x4E8E;&#x534F;&#x8C03;&#x8282;&#x70B9;&#x77E5;&#x9053;&#x6BCF;&#x4E2A;&#x6587;&#x6863;&#x5B58;&#x5728;&#x4E8E;&#x54EA;&#x4E2A;&#x5206;&#x7247;&#x4E2D;&#x3002; &#x5B83;&#x5C06;&#x6574;&#x4E2A;&#x591A;&#x6587;&#x6863;&#x8BF7;&#x6C42;&#x5206;&#x89E3;&#x6210; <em>&#x6BCF;&#x4E2A;&#x5206;&#x7247;</em> &#x7684;&#x591A;&#x6587;&#x6863;&#x8BF7;&#x6C42;&#xFF0C;&#x5E76;&#x4E14;&#x5C06;&#x8FD9;&#x4E9B;&#x8BF7;&#x6C42;&#x5E76;&#x884C;&#x8F6C;&#x53D1;&#x5230;&#x6BCF;&#x4E2A;&#x53C2;&#x4E0E;&#x8282;&#x70B9;&#x3002;</p>
<p>&#x534F;&#x8C03;&#x8282;&#x70B9;&#x4E00;&#x65E6;&#x6536;&#x5230;&#x6765;&#x81EA;&#x6BCF;&#x4E2A;&#x8282;&#x70B9;&#x7684;&#x5E94;&#x7B54;&#xFF0C;&#x5C31;&#x5C06;&#x6BCF;&#x4E2A;&#x8282;&#x70B9;&#x7684;&#x54CD;&#x5E94;&#x6536;&#x96C6;&#x6574;&#x7406;&#x6210;&#x5355;&#x4E2A;&#x54CD;&#x5E94;&#xFF0C;&#x8FD4;&#x56DE;&#x7ED9;&#x5BA2;&#x6237;&#x7AEF;&#xFF0C;&#x5982; <a href="https://www.elastic.co/guide/cn/elasticsearch/guide/current/distrib-multi-doc.html#img-distrib-mget" target="_blank">&#x56FE; 12 &#x201C;&#x4F7F;&#x7528; <code>mget</code> &#x53D6;&#x56DE;&#x591A;&#x4E2A;&#x6587;&#x6863;&#x201D;</a> &#x6240;&#x793A;&#x3002;</p>
<p><strong>&#x56FE; 12. &#x4F7F;&#x7528; mget &#x53D6;&#x56DE;&#x591A;&#x4E2A;&#x6587;&#x6863;</strong></p>
<p><img src="assets/elas_0405.png" alt="&#x201C;&#x4F7F;&#x7528; `mget` &#x53D6;&#x56DE;&#x591A;&#x4E2A;&#x6587;&#x6863;&#x201D;"></p>
<p>&#x4EE5;&#x4E0B;&#x662F;&#x4F7F;&#x7528;&#x5355;&#x4E2A; <code>mget</code> &#x8BF7;&#x6C42;&#x53D6;&#x56DE;&#x591A;&#x4E2A;&#x6587;&#x6863;&#x6240;&#x9700;&#x7684;&#x6B65;&#x9AA4;&#x987A;&#x5E8F;&#xFF1A;</p>
<ol>
<li>&#x5BA2;&#x6237;&#x7AEF;&#x5411; <code>Node 1</code> &#x53D1;&#x9001; <code>mget</code> &#x8BF7;&#x6C42;&#x3002;</li>
<li><code>Node 1</code> &#x4E3A;&#x6BCF;&#x4E2A;&#x5206;&#x7247;&#x6784;&#x5EFA;&#x591A;&#x6587;&#x6863;&#x83B7;&#x53D6;&#x8BF7;&#x6C42;&#xFF0C;&#x7136;&#x540E;&#x5E76;&#x884C;&#x8F6C;&#x53D1;&#x8FD9;&#x4E9B;&#x8BF7;&#x6C42;&#x5230;&#x6258;&#x7BA1;&#x5728;&#x6BCF;&#x4E2A;&#x6240;&#x9700;&#x7684;&#x4E3B;&#x5206;&#x7247;&#x6216;&#x8005;&#x526F;&#x672C;&#x5206;&#x7247;&#x7684;&#x8282;&#x70B9;&#x4E0A;&#x3002;&#x4E00;&#x65E6;&#x6536;&#x5230;&#x6240;&#x6709;&#x7B54;&#x590D;&#xFF0C; <code>Node 1</code> &#x6784;&#x5EFA;&#x54CD;&#x5E94;&#x5E76;&#x5C06;&#x5176;&#x8FD4;&#x56DE;&#x7ED9;&#x5BA2;&#x6237;&#x7AEF;&#x3002;</li>
</ol>
<p>&#x53EF;&#x4EE5;&#x5BF9; <code>docs</code> &#x6570;&#x7EC4;&#x4E2D;&#x6BCF;&#x4E2A;&#x6587;&#x6863;&#x8BBE;&#x7F6E; <code>routing</code> &#x53C2;&#x6570;&#x3002;</p>
<p>bulk API&#xFF0C; &#x5982; <a href="https://www.elastic.co/guide/cn/elasticsearch/guide/current/distrib-multi-doc.html#img-distrib-bulk" target="_blank">&#x56FE; 13 &#x201C;&#x4F7F;&#x7528; <code>bulk</code> &#x4FEE;&#x6539;&#x591A;&#x4E2A;&#x6587;&#x6863;&#x201D;</a> &#x6240;&#x793A;&#xFF0C; &#x5141;&#x8BB8;&#x5728;&#x5355;&#x4E2A;&#x6279;&#x91CF;&#x8BF7;&#x6C42;&#x4E2D;&#x6267;&#x884C;&#x591A;&#x4E2A;&#x521B;&#x5EFA;&#x3001;&#x7D22;&#x5F15;&#x3001;&#x5220;&#x9664;&#x548C;&#x66F4;&#x65B0;&#x8BF7;&#x6C42;&#x3002;</p>
<p><strong>&#x56FE; 13. &#x4F7F;&#x7528; bulk &#x4FEE;&#x6539;&#x591A;&#x4E2A;&#x6587;&#x6863;</strong></p>
<p><img src="assets/elas_0406.png" alt="&#x201C;&#x4F7F;&#x7528; `bulk` &#x4FEE;&#x6539;&#x591A;&#x4E2A;&#x6587;&#x6863;&#x201D;"></p>
<p><code>bulk</code> API &#x6309;&#x5982;&#x4E0B;&#x6B65;&#x9AA4;&#x987A;&#x5E8F;&#x6267;&#x884C;&#xFF1A;</p>
<ol>
<li>&#x5BA2;&#x6237;&#x7AEF;&#x5411; <code>Node 1</code> &#x53D1;&#x9001; <code>bulk</code> &#x8BF7;&#x6C42;&#x3002;</li>
<li><code>Node 1</code> &#x4E3A;&#x6BCF;&#x4E2A;&#x8282;&#x70B9;&#x521B;&#x5EFA;&#x4E00;&#x4E2A;&#x6279;&#x91CF;&#x8BF7;&#x6C42;&#xFF0C;&#x5E76;&#x5C06;&#x8FD9;&#x4E9B;&#x8BF7;&#x6C42;&#x5E76;&#x884C;&#x8F6C;&#x53D1;&#x5230;&#x6BCF;&#x4E2A;&#x5305;&#x542B;&#x4E3B;&#x5206;&#x7247;&#x7684;&#x8282;&#x70B9;&#x4E3B;&#x673A;&#x3002;</li>
<li>&#x4E3B;&#x5206;&#x7247;&#x4E00;&#x4E2A;&#x63A5;&#x4E00;&#x4E2A;&#x6309;&#x987A;&#x5E8F;&#x6267;&#x884C;&#x6BCF;&#x4E2A;&#x64CD;&#x4F5C;&#x3002;&#x5F53;&#x6BCF;&#x4E2A;&#x64CD;&#x4F5C;&#x6210;&#x529F;&#x65F6;&#xFF0C;&#x4E3B;&#x5206;&#x7247;&#x5E76;&#x884C;&#x8F6C;&#x53D1;&#x65B0;&#x6587;&#x6863;&#xFF08;&#x6216;&#x5220;&#x9664;&#xFF09;&#x5230;&#x526F;&#x672C;&#x5206;&#x7247;&#xFF0C;&#x7136;&#x540E;&#x6267;&#x884C;&#x4E0B;&#x4E00;&#x4E2A;&#x64CD;&#x4F5C;&#x3002; &#x4E00;&#x65E6;&#x6240;&#x6709;&#x7684;&#x526F;&#x672C;&#x5206;&#x7247;&#x62A5;&#x544A;&#x6240;&#x6709;&#x64CD;&#x4F5C;&#x6210;&#x529F;&#xFF0C;&#x8BE5;&#x8282;&#x70B9;&#x5C06;&#x5411;&#x534F;&#x8C03;&#x8282;&#x70B9;&#x62A5;&#x544A;&#x6210;&#x529F;&#xFF0C;&#x534F;&#x8C03;&#x8282;&#x70B9;&#x5C06;&#x8FD9;&#x4E9B;&#x54CD;&#x5E94;&#x6536;&#x96C6;&#x6574;&#x7406;&#x5E76;&#x8FD4;&#x56DE;&#x7ED9;&#x5BA2;&#x6237;&#x7AEF;&#x3002;</li>
</ol>
<p><code>bulk</code> API &#x8FD8;&#x53EF;&#x4EE5;&#x5728;&#x6574;&#x4E2A;&#x6279;&#x91CF;&#x8BF7;&#x6C42;&#x7684;&#x6700;&#x9876;&#x5C42;&#x4F7F;&#x7528; <code>consistency</code> &#x53C2;&#x6570;&#xFF0C;&#x4EE5;&#x53CA;&#x5728;&#x6BCF;&#x4E2A;&#x8BF7;&#x6C42;&#x4E2D;&#x7684;&#x5143;&#x6570;&#x636E;&#x4E2D;&#x4F7F;&#x7528; <code>routing</code> &#x53C2;&#x6570;&#x3002;</p>
<p><strong>&#x4E3A;&#x4EC0;&#x4E48;&#x662F;&#x6709;&#x8DA3;&#x7684;&#x683C;&#x5F0F;&#xFF1F;</strong></p>
<p>&#x5F53;&#x6211;&#x4EEC;&#x65E9;&#x4E9B;&#x65F6;&#x5019;&#x5728;<a href="https://www.elastic.co/guide/cn/elasticsearch/guide/current/bulk.html" target="_blank">&#x4EE3;&#x4EF7;&#x8F83;&#x5C0F;&#x7684;&#x6279;&#x91CF;&#x64CD;&#x4F5C;</a>&#x7AE0;&#x8282;&#x4E86;&#x89E3;&#x6279;&#x91CF;&#x8BF7;&#x6C42;&#x65F6;&#xFF0C; &#x60A8;&#x53EF;&#x80FD;&#x4F1A;&#x95EE;&#x81EA;&#x5DF1;&#xFF0C; &quot;&#x4E3A;&#x4EC0;&#x4E48; <code>bulk</code> API &#x9700;&#x8981;&#x6709;&#x6362;&#x884C;&#x7B26;&#x7684;&#x6709;&#x8DA3;&#x683C;&#x5F0F;&#xFF0C;&#x800C;&#x4E0D;&#x662F;&#x53D1;&#x9001;&#x5305;&#x88C5;&#x5728; JSON &#x6570;&#x7EC4;&#x4E2D;&#x7684;&#x8BF7;&#x6C42;&#xFF0C;&#x4F8B;&#x5982; <code>mget</code> API&#xFF1F;&quot; &#x3002;</p>
<p>&#x4E3A;&#x4E86;&#x56DE;&#x7B54;&#x8FD9;&#x4E00;&#x70B9;&#xFF0C;&#x6211;&#x4EEC;&#x9700;&#x8981;&#x89E3;&#x91CA;&#x4E00;&#x70B9;&#x80CC;&#x666F;&#xFF1A;&#x5728;&#x6279;&#x91CF;&#x8BF7;&#x6C42;&#x4E2D;&#x5F15;&#x7528;&#x7684;&#x6BCF;&#x4E2A;&#x6587;&#x6863;&#x53EF;&#x80FD;&#x5C5E;&#x4E8E;&#x4E0D;&#x540C;&#x7684;&#x4E3B;&#x5206;&#x7247;&#xFF0C; &#x6BCF;&#x4E2A;&#x6587;&#x6863;&#x53EF;&#x80FD;&#x88AB;&#x5206;&#x914D;&#x7ED9;&#x96C6;&#x7FA4;&#x4E2D;&#x7684;&#x4EFB;&#x4F55;&#x8282;&#x70B9;&#x3002;&#x8FD9;&#x610F;&#x5473;&#x7740;&#x6279;&#x91CF;&#x8BF7;&#x6C42; <code>bulk</code> &#x4E2D;&#x7684;&#x6BCF;&#x4E2A; <em>&#x64CD;&#x4F5C;</em> &#x90FD;&#x9700;&#x8981;&#x88AB;&#x8F6C;&#x53D1;&#x5230;&#x6B63;&#x786E;&#x8282;&#x70B9;&#x4E0A;&#x7684;&#x6B63;&#x786E;&#x5206;&#x7247;&#x3002;</p>
<p>&#x5982;&#x679C;&#x5355;&#x4E2A;&#x8BF7;&#x6C42;&#x88AB;&#x5305;&#x88C5;&#x5728; JSON &#x6570;&#x7EC4;&#x4E2D;&#xFF0C;&#x90A3;&#x5C31;&#x610F;&#x5473;&#x7740;&#x6211;&#x4EEC;&#x9700;&#x8981;&#x6267;&#x884C;&#x4EE5;&#x4E0B;&#x64CD;&#x4F5C;&#xFF1A;</p>
<ul>
<li>&#x5C06; JSON &#x89E3;&#x6790;&#x4E3A;&#x6570;&#x7EC4;&#xFF08;&#x5305;&#x62EC;&#x6587;&#x6863;&#x6570;&#x636E;&#xFF0C;&#x53EF;&#x4EE5;&#x975E;&#x5E38;&#x5927;&#xFF09;</li>
<li>&#x67E5;&#x770B;&#x6BCF;&#x4E2A;&#x8BF7;&#x6C42;&#x4EE5;&#x786E;&#x5B9A;&#x5E94;&#x8BE5;&#x53BB;&#x54EA;&#x4E2A;&#x5206;&#x7247;</li>
<li>&#x4E3A;&#x6BCF;&#x4E2A;&#x5206;&#x7247;&#x521B;&#x5EFA;&#x4E00;&#x4E2A;&#x8BF7;&#x6C42;&#x6570;&#x7EC4;</li>
<li>&#x5C06;&#x8FD9;&#x4E9B;&#x6570;&#x7EC4;&#x5E8F;&#x5217;&#x5316;&#x4E3A;&#x5185;&#x90E8;&#x4F20;&#x8F93;&#x683C;&#x5F0F;</li>
<li>&#x5C06;&#x8BF7;&#x6C42;&#x53D1;&#x9001;&#x5230;&#x6BCF;&#x4E2A;&#x5206;&#x7247;</li>
</ul>
<p>&#x8FD9;&#x662F;&#x53EF;&#x884C;&#x7684;&#xFF0C;&#x4F46;&#x9700;&#x8981;&#x5927;&#x91CF;&#x7684; RAM &#x6765;&#x5B58;&#x50A8;&#x539F;&#x672C;&#x76F8;&#x540C;&#x7684;&#x6570;&#x636E;&#x7684;&#x526F;&#x672C;&#xFF0C;&#x5E76;&#x5C06;&#x521B;&#x5EFA;&#x66F4;&#x591A;&#x7684;&#x6570;&#x636E;&#x7ED3;&#x6784;&#xFF0C;Java&#x865A;&#x62DF;&#x673A;&#xFF08;JVM&#xFF09;&#x5C06;&#x4E0D;&#x5F97;&#x4E0D;&#x82B1;&#x8D39;&#x65F6;&#x95F4;&#x8FDB;&#x884C;&#x5783;&#x573E;&#x56DE;&#x6536;&#x3002;</p>
<p>&#x76F8;&#x53CD;&#xFF0C;Elasticsearch&#x53EF;&#x4EE5;&#x76F4;&#x63A5;&#x8BFB;&#x53D6;&#x88AB;&#x7F51;&#x7EDC;&#x7F13;&#x51B2;&#x533A;&#x63A5;&#x6536;&#x7684;&#x539F;&#x59CB;&#x6570;&#x636E;&#x3002; &#x5B83;&#x4F7F;&#x7528;&#x6362;&#x884C;&#x7B26;&#x5B57;&#x7B26;&#x6765;&#x8BC6;&#x522B;&#x548C;&#x89E3;&#x6790;&#x5C0F;&#x7684; <code>action/metadata</code> &#x884C;&#x6765;&#x51B3;&#x5B9A;&#x54EA;&#x4E2A;&#x5206;&#x7247;&#x5E94;&#x8BE5;&#x5904;&#x7406;&#x6BCF;&#x4E2A;&#x8BF7;&#x6C42;&#x3002;</p>
<p>&#x8FD9;&#x4E9B;&#x539F;&#x59CB;&#x8BF7;&#x6C42;&#x4F1A;&#x88AB;&#x76F4;&#x63A5;&#x8F6C;&#x53D1;&#x5230;&#x6B63;&#x786E;&#x7684;&#x5206;&#x7247;&#x3002;&#x6CA1;&#x6709;&#x5197;&#x4F59;&#x7684;&#x6570;&#x636E;&#x590D;&#x5236;&#xFF0C;&#x6CA1;&#x6709;&#x6D6A;&#x8D39;&#x7684;&#x6570;&#x636E;&#x7ED3;&#x6784;&#x3002;&#x6574;&#x4E2A;&#x8BF7;&#x6C42;&#x5C3D;&#x53EF;&#x80FD;&#x5728;&#x6700;&#x5C0F;&#x7684;&#x5185;&#x5B58;&#x4E2D;&#x5904;&#x7406;&#x3002;</p>
<h2 id="&#x641C;&#x7D22;&#x6700;&#x57FA;&#x672C;&#x7684;&#x5DE5;&#x5177;"><a name="&#x641C;&#x7D22;&#x6700;&#x57FA;&#x672C;&#x7684;&#x5DE5;&#x5177;" class="anchor-navigation-ex-anchor" href="#&#x641C;&#x7D22;&#x6700;&#x57FA;&#x672C;&#x7684;&#x5DE5;&#x5177;"><i class="fa fa-link" aria-hidden="true"></i></a>&#x641C;&#x7D22;&#x2014;&#x2014;&#x6700;&#x57FA;&#x672C;&#x7684;&#x5DE5;&#x5177;  </h2>
<p>&#x73B0;&#x5728;&#xFF0C;&#x6211;&#x4EEC;&#x5DF2;&#x7ECF;&#x5B66;&#x4F1A;&#x4E86;&#x5982;&#x4F55;&#x4F7F;&#x7528; Elasticsearch &#x4F5C;&#x4E3A;&#x4E00;&#x4E2A;&#x7B80;&#x5355;&#x7684; NoSQL &#x98CE;&#x683C;&#x7684;&#x5206;&#x5E03;&#x5F0F;&#x6587;&#x6863;&#x5B58;&#x50A8;&#x7CFB;&#x7EDF;&#x3002;&#x6211;&#x4EEC;&#x53EF;&#x4EE5;&#x5C06;&#x4E00;&#x4E2A; JSON &#x6587;&#x6863;&#x6254;&#x5230; Elasticsearch &#x91CC;&#xFF0C;&#x7136;&#x540E;&#x6839;&#x636E; ID &#x68C0;&#x7D22;&#x3002;&#x4F46; Elasticsearch &#x771F;&#x6B63;&#x5F3A;&#x5927;&#x4E4B;&#x5904;&#x5728;&#x4E8E;&#x53EF;&#x4EE5;&#x4ECE;&#x65E0;&#x89C4;&#x5F8B;&#x7684;&#x6570;&#x636E;&#x4E2D;&#x627E;&#x51FA;&#x6709;&#x610F;&#x4E49;&#x7684;&#x4FE1;&#x606F;&#x2014;&#x2014;&#x4ECE;&#x201C;&#x5927;&#x6570;&#x636E;&#x201D;&#x5230;&#x201C;&#x5927;&#x4FE1;&#x606F;&#x201D;&#x3002;</p>
<p>Elasticsearch &#x4E0D;&#x53EA;&#x4F1A;<em>&#x5B58;&#x50A8;&#xFF08;stores&#xFF09;</em> &#x6587;&#x6863;&#xFF0C;&#x4E3A;&#x4E86;&#x80FD;&#x88AB;&#x641C;&#x7D22;&#x5230;&#x4E5F;&#x4F1A;&#x4E3A;&#x6587;&#x6863;&#x6DFB;&#x52A0;<em>&#x7D22;&#x5F15;&#xFF08;indexes&#xFF09;</em> &#xFF0C;&#x8FD9;&#x4E5F;&#x662F;&#x4E3A;&#x4EC0;&#x4E48;&#x6211;&#x4EEC;&#x4F7F;&#x7528;&#x7ED3;&#x6784;&#x5316;&#x7684; JSON &#x6587;&#x6863;&#xFF0C;&#x800C;&#x4E0D;&#x662F;&#x65E0;&#x7ED3;&#x6784;&#x7684;&#x4E8C;&#x8FDB;&#x5236;&#x6570;&#x636E;&#x3002;</p>
<p><em>&#x6587;&#x6863;&#x4E2D;&#x7684;&#x6BCF;&#x4E2A;&#x5B57;&#x6BB5;&#x90FD;&#x5C06;&#x88AB;&#x7D22;&#x5F15;&#x5E76;&#x4E14;&#x53EF;&#x4EE5;&#x88AB;&#x67E5;&#x8BE2;</em> &#x3002;&#x4E0D;&#x4EC5;&#x5982;&#x6B64;&#xFF0C;&#x5728;&#x7B80;&#x5355;&#x67E5;&#x8BE2;&#x65F6;&#xFF0C;Elasticsearch &#x53EF;&#x4EE5;&#x4F7F;&#x7528; <em>&#x6240;&#x6709;&#xFF08;all&#xFF09;</em> &#x8FD9;&#x4E9B;&#x7D22;&#x5F15;&#x5B57;&#x6BB5;&#xFF0C;&#x4EE5;&#x60CA;&#x4EBA;&#x7684;&#x901F;&#x5EA6;&#x8FD4;&#x56DE;&#x7ED3;&#x679C;&#x3002;&#x8FD9;&#x662F;&#x4F60;&#x6C38;&#x8FDC;&#x4E0D;&#x4F1A;&#x8003;&#x8651;&#x7528;&#x4F20;&#x7EDF;&#x6570;&#x636E;&#x5E93;&#x53BB;&#x505A;&#x7684;&#x4E00;&#x4E9B;&#x4E8B;&#x60C5;&#x3002;</p>
<p><em>&#x641C;&#x7D22;&#xFF08;search&#xFF09;</em> &#x53EF;&#x4EE5;&#x505A;&#x5230;&#xFF1A;</p>
<ul>
<li>&#x5728;&#x7C7B;&#x4F3C;&#x4E8E; <code>gender</code> &#x6216;&#x8005; <code>age</code> &#x8FD9;&#x6837;&#x7684;&#x5B57;&#x6BB5; &#x4E0A;&#x4F7F;&#x7528;&#x7ED3;&#x6784;&#x5316;&#x67E5;&#x8BE2;&#xFF0C;<code>join_date</code> &#x8FD9;&#x6837;&#x7684;&#x5B57;&#x6BB5;&#x4E0A;&#x4F7F;&#x7528;&#x6392;&#x5E8F;&#xFF0C;&#x5C31;&#x50CF;SQL&#x7684;&#x7ED3;&#x6784;&#x5316;&#x67E5;&#x8BE2;&#x4E00;&#x6837;&#x3002;</li>
<li>&#x5168;&#x6587;&#x68C0;&#x7D22;&#xFF0C;&#x627E;&#x51FA;&#x6240;&#x6709;&#x5339;&#x914D;&#x5173;&#x952E;&#x5B57;&#x7684;&#x6587;&#x6863;&#x5E76;&#x6309;&#x7167;<em>&#x76F8;&#x5173;&#x6027;&#xFF08;relevance&#xFF09;</em> &#x6392;&#x5E8F;&#x540E;&#x8FD4;&#x56DE;&#x7ED3;&#x679C;&#x3002;</li>
<li>&#x4EE5;&#x4E0A;&#x4E8C;&#x8005;&#x517C;&#x800C;&#x6709;&#x4E4B;&#x3002;</li>
</ul>
<p>&#x5F88;&#x591A;&#x641C;&#x7D22;&#x90FD;&#x662F;&#x5F00;&#x7BB1;&#x5373;&#x7528;&#x7684;&#xFF0C;&#x4E3A;&#x4E86;&#x5145;&#x5206;&#x6316;&#x6398; Elasticsearch &#x7684;&#x6F5C;&#x529B;&#xFF0C;&#x4F60;&#x9700;&#x8981;&#x7406;&#x89E3;&#x4EE5;&#x4E0B;&#x4E09;&#x4E2A;&#x6982;&#x5FF5;&#xFF1A;</p>
<ul>
<li><p><em>&#x6620;&#x5C04;&#xFF08;Mapping&#xFF09;</em></p>
<p>&#x63CF;&#x8FF0;&#x6570;&#x636E;&#x5728;&#x6BCF;&#x4E2A;&#x5B57;&#x6BB5;&#x5185;&#x5982;&#x4F55;&#x5B58;&#x50A8;</p>
</li>
<li><p><em>&#x5206;&#x6790;&#xFF08;Analysis&#xFF09;</em></p>
<p>&#x5168;&#x6587;&#x662F;&#x5982;&#x4F55;&#x5904;&#x7406;&#x4F7F;&#x4E4B;&#x53EF;&#x4EE5;&#x88AB;&#x641C;&#x7D22;&#x7684;</p>
</li>
<li><p><em>&#x9886;&#x57DF;&#x7279;&#x5B9A;&#x67E5;&#x8BE2;&#x8BED;&#x8A00;&#xFF08;Query DSL&#xFF09;</em></p>
<p>Elasticsearch &#x4E2D;&#x5F3A;&#x5927;&#x7075;&#x6D3B;&#x7684;&#x67E5;&#x8BE2;&#x8BED;&#x8A00;</p>
</li>
</ul>
<p>&#x4EE5;&#x4E0A;&#x63D0;&#x5230;&#x7684;&#x6BCF;&#x4E2A;&#x70B9;&#x90FD;&#x662F;&#x4E00;&#x4E2A;&#x5927;&#x8BDD;&#x9898;&#xFF0C;&#x6211;&#x4EEC;&#x5C06;&#x5728; <a href="https://www.elastic.co/guide/cn/elasticsearch/guide/current/search-in-depth.html" target="_blank">&#x6DF1;&#x5165;&#x641C;&#x7D22;</a> &#x4E00;&#x7AE0;&#x8BE6;&#x7EC6;&#x9610;&#x8FF0;&#x5B83;&#x4EEC;&#x3002;&#x672C;&#x7AE0;&#x8282;&#x6211;&#x4EEC;&#x5C06;&#x4ECB;&#x7ECD;&#x8FD9;&#x4E09;&#x70B9;&#x7684;&#x4E00;&#x4E9B;&#x57FA;&#x672C;&#x6982;&#x5FF5;&#x2014;&#x2014;&#x4EC5;&#x4EC5;&#x5E2E;&#x52A9;&#x4F60;&#x5927;&#x81F4;&#x4E86;&#x89E3;&#x641C;&#x7D22;&#x662F;&#x5982;&#x4F55;&#x5DE5;&#x4F5C;&#x7684;&#x3002;</p>
<p>&#x6211;&#x4EEC;&#x5C06;&#x4F7F;&#x7528;&#x6700;&#x7B80;&#x5355;&#x7684;&#x5F62;&#x5F0F;&#x5F00;&#x59CB;&#x4ECB;&#x7ECD; <code>search</code> API&#x3002;</p>
<hr>
<blockquote>
<p> <strong>&#x6D4B;&#x8BD5;&#x6570;&#x636E;</strong></p>
<p> &#x672C;&#x7AE0;&#x8282;&#x7684;&#x6D4B;&#x8BD5;&#x6570;&#x636E;&#x53EF;&#x4EE5;&#x5728;&#x8FD9;&#x91CC;&#x627E;&#x5230;&#xFF1A; <a href="https://gist.github.com/clintongormley/8579281" target="_blank">https://gist.github.com/clintongormley/8579281</a> &#x3002;</p>
<p> &#x4F60;&#x53EF;&#x4EE5;&#x628A;&#x8FD9;&#x4E9B;&#x547D;&#x4EE4;&#x590D;&#x5236;&#x5230;&#x7EC8;&#x7AEF;&#x4E2D;&#x6267;&#x884C;&#x6765;&#x5B9E;&#x8DF5;&#x672C;&#x7AE0;&#x7684;&#x4F8B;&#x5B50;&#x3002;</p>
<p> &#x53E6;&#x5916;&#xFF0C;&#x5982;&#x679C;&#x4F60;&#x8BFB;&#x7684;&#x662F;&#x5728;&#x7EBF;&#x7248;&#x672C;&#xFF0C;&#x53EF;&#x4EE5; <a href="https://www.elastic.co/guide/cn/elasticsearch/guide/current/sense_widget.html?snippets/050_Search/Test_data.json" target="_blank">&#x70B9;&#x51FB;&#x8FD9;&#x4E2A;&#x94FE;&#x63A5;</a> &#x611F;&#x53D7;&#x4E0B;&#x3002;</p>
</blockquote>
<hr>
<h3 id="&#x7A7A;&#x641C;&#x7D22;"><a name="&#x7A7A;&#x641C;&#x7D22;" class="anchor-navigation-ex-anchor" href="#&#x7A7A;&#x641C;&#x7D22;"><i class="fa fa-link" aria-hidden="true"></i></a>&#x7A7A;&#x641C;&#x7D22;</h3>
<p>&#x641C;&#x7D22;API&#x7684;&#x6700;&#x57FA;&#x7840;&#x7684;&#x5F62;&#x5F0F;&#x662F;&#x6CA1;&#x6709;&#x6307;&#x5B9A;&#x4EFB;&#x4F55;&#x67E5;&#x8BE2;&#x7684;&#x7A7A;&#x641C;&#x7D22; &#xFF0C;&#x5B83;&#x7B80;&#x5355;&#x5730;&#x8FD4;&#x56DE;&#x96C6;&#x7FA4;&#x4E2D;&#x6240;&#x6709;&#x7D22;&#x5F15;&#x4E0B;&#x7684;&#x6240;&#x6709;&#x6587;&#x6863;&#xFF1A;</p>
<pre><code class="lang-js">GET /_search
</code></pre>
<p>&#x8FD4;&#x56DE;&#x7684;&#x7ED3;&#x679C;&#xFF08;&#x4E3A;&#x4E86;&#x754C;&#x9762;&#x7B80;&#x6D01;&#x7F16;&#x8F91;&#x8FC7;&#x7684;&#xFF09;&#x50CF;&#x8FD9;&#x6837;&#xFF1A;</p>
<pre><code class="lang-js">{
   <span class="hljs-string">&quot;hits&quot;</span> : {
      <span class="hljs-string">&quot;total&quot;</span> :       <span class="hljs-number">14</span>,
      <span class="hljs-string">&quot;hits&quot;</span> : [
        {
          <span class="hljs-string">&quot;_index&quot;</span>:   <span class="hljs-string">&quot;us&quot;</span>,
          <span class="hljs-string">&quot;_type&quot;</span>:    <span class="hljs-string">&quot;tweet&quot;</span>,
          <span class="hljs-string">&quot;_id&quot;</span>:      <span class="hljs-string">&quot;7&quot;</span>,
          <span class="hljs-string">&quot;_score&quot;</span>:   <span class="hljs-number">1</span>,
          <span class="hljs-string">&quot;_source&quot;</span>: {
             <span class="hljs-string">&quot;date&quot;</span>:    <span class="hljs-string">&quot;2014-09-17&quot;</span>,
             <span class="hljs-string">&quot;name&quot;</span>:    <span class="hljs-string">&quot;John Smith&quot;</span>,
             <span class="hljs-string">&quot;tweet&quot;</span>:   <span class="hljs-string">&quot;The Query DSL is really powerful and flexible&quot;</span>,
             <span class="hljs-string">&quot;user_id&quot;</span>: <span class="hljs-number">2</span>
          }
       },
        ... <span class="hljs-number">9</span> RESULTS REMOVED ...
      ],
      <span class="hljs-string">&quot;max_score&quot;</span> :   <span class="hljs-number">1</span>
   },
   <span class="hljs-string">&quot;took&quot;</span> :           <span class="hljs-number">4</span>,
   <span class="hljs-string">&quot;_shards&quot;</span> : {
      <span class="hljs-string">&quot;failed&quot;</span> :      <span class="hljs-number">0</span>,
      <span class="hljs-string">&quot;successful&quot;</span> :  <span class="hljs-number">10</span>,
      <span class="hljs-string">&quot;total&quot;</span> :       <span class="hljs-number">10</span>
   },
   <span class="hljs-string">&quot;timed_out&quot;</span> :      <span class="hljs-literal">false</span>
}
</code></pre>
<p><strong>hits</strong></p>
<p>&#x8FD4;&#x56DE;&#x7ED3;&#x679C;&#x4E2D;&#x6700;&#x91CD;&#x8981;&#x7684;&#x90E8;&#x5206;&#x662F; <code>hits</code> &#xFF0C;&#x5B83; &#x5305;&#x542B; <code>total</code> &#x5B57;&#x6BB5;&#x6765;&#x8868;&#x793A;&#x5339;&#x914D;&#x5230;&#x7684;&#x6587;&#x6863;&#x603B;&#x6570;&#xFF0C;&#x5E76;&#x4E14;&#x4E00;&#x4E2A; <code>hits</code> &#x6570;&#x7EC4;&#x5305;&#x542B;&#x6240;&#x67E5;&#x8BE2;&#x7ED3;&#x679C;&#x7684;&#x524D;&#x5341;&#x4E2A;&#x6587;&#x6863;&#x3002;</p>
<p>&#x5728; <code>hits</code> &#x6570;&#x7EC4;&#x4E2D;&#x6BCF;&#x4E2A;&#x7ED3;&#x679C;&#x5305;&#x542B;&#x6587;&#x6863;&#x7684; <code>_index</code> &#x3001; <code>_type</code> &#x3001; <code>_id</code> &#xFF0C;&#x52A0;&#x4E0A; <code>_source</code> &#x5B57;&#x6BB5;&#x3002;&#x8FD9;&#x610F;&#x5473;&#x7740;&#x6211;&#x4EEC;&#x53EF;&#x4EE5;&#x76F4;&#x63A5;&#x4ECE;&#x8FD4;&#x56DE;&#x7684;&#x641C;&#x7D22;&#x7ED3;&#x679C;&#x4E2D;&#x4F7F;&#x7528;&#x6574;&#x4E2A;&#x6587;&#x6863;&#x3002;&#x8FD9;&#x4E0D;&#x50CF;&#x5176;&#x4ED6;&#x7684;&#x641C;&#x7D22;&#x5F15;&#x64CE;&#xFF0C;&#x4EC5;&#x4EC5;&#x8FD4;&#x56DE;&#x6587;&#x6863;&#x7684;ID&#xFF0C;&#x9700;&#x8981;&#x4F60;&#x5355;&#x72EC;&#x53BB;&#x83B7;&#x53D6;&#x6587;&#x6863;&#x3002;</p>
<p>&#x6BCF;&#x4E2A;&#x7ED3;&#x679C;&#x8FD8;&#x6709;&#x4E00;&#x4E2A; <code>_score</code> &#xFF0C;&#x5B83;&#x8861;&#x91CF;&#x4E86;&#x6587;&#x6863;&#x4E0E;&#x67E5;&#x8BE2;&#x7684;&#x5339;&#x914D;&#x7A0B;&#x5EA6;&#x3002;&#x9ED8;&#x8BA4;&#x60C5;&#x51B5;&#x4E0B;&#xFF0C;&#x9996;&#x5148;&#x8FD4;&#x56DE;&#x6700;&#x76F8;&#x5173;&#x7684;&#x6587;&#x6863;&#x7ED3;&#x679C;&#xFF0C;&#x5C31;&#x662F;&#x8BF4;&#xFF0C;&#x8FD4;&#x56DE;&#x7684;&#x6587;&#x6863;&#x662F;&#x6309;&#x7167; <code>_score</code> &#x964D;&#x5E8F;&#x6392;&#x5217;&#x7684;&#x3002;&#x5728;&#x8FD9;&#x4E2A;&#x4F8B;&#x5B50;&#x4E2D;&#xFF0C;&#x6211;&#x4EEC;&#x6CA1;&#x6709;&#x6307;&#x5B9A;&#x4EFB;&#x4F55;&#x67E5;&#x8BE2;&#xFF0C;&#x6545;&#x6240;&#x6709;&#x7684;&#x6587;&#x6863;&#x5177;&#x6709;&#x76F8;&#x540C;&#x7684;&#x76F8;&#x5173;&#x6027;&#xFF0C;&#x56E0;&#x6B64;&#x5BF9;&#x6240;&#x6709;&#x7684;&#x7ED3;&#x679C;&#x800C;&#x8A00; <code>1</code> &#x662F;&#x4E2D;&#x6027;&#x7684; <code>_score</code> &#x3002;</p>
<p><code>max_score</code> &#x503C;&#x662F;&#x4E0E;&#x67E5;&#x8BE2;&#x6240;&#x5339;&#x914D;&#x6587;&#x6863;&#x7684; <code>_score</code> &#x7684;&#x6700;&#x5927;&#x503C;&#x3002;</p>
<p><strong>took</strong></p>
<p><code>took</code> &#x503C;&#x544A;&#x8BC9;&#x6211;&#x4EEC;&#x6267;&#x884C;&#x6574;&#x4E2A;&#x641C;&#x7D22;&#x8BF7;&#x6C42;&#x8017;&#x8D39;&#x4E86;&#x591A;&#x5C11;&#x6BEB;&#x79D2;&#x3002;</p>
<p><strong>shards</strong></p>
<p><code>_shards</code> &#x90E8;&#x5206; &#x544A;&#x8BC9;&#x6211;&#x4EEC;&#x5728;&#x67E5;&#x8BE2;&#x4E2D;&#x53C2;&#x4E0E;&#x5206;&#x7247;&#x7684;&#x603B;&#x6570;&#xFF0C;&#x4EE5;&#x53CA;&#x8FD9;&#x4E9B;&#x5206;&#x7247;&#x6210;&#x529F;&#x4E86;&#x591A;&#x5C11;&#x4E2A;&#x5931;&#x8D25;&#x4E86;&#x591A;&#x5C11;&#x4E2A;&#x3002;&#x6B63;&#x5E38;&#x60C5;&#x51B5;&#x4E0B;&#x6211;&#x4EEC;&#x4E0D;&#x5E0C;&#x671B;&#x5206;&#x7247;&#x5931;&#x8D25;&#xFF0C;&#x4F46;&#x662F;&#x5206;&#x7247;&#x5931;&#x8D25;&#x662F;&#x53EF;&#x80FD;&#x53D1;&#x751F;&#x7684;&#x3002;&#x5982;&#x679C;&#x6211;&#x4EEC;&#x906D;&#x9047;&#x5230;&#x4E00;&#x79CD;&#x707E;&#x96BE;&#x7EA7;&#x522B;&#x7684;&#x6545;&#x969C;&#xFF0C;&#x5728;&#x8FD9;&#x4E2A;&#x6545;&#x969C;&#x4E2D;&#x4E22;&#x5931;&#x4E86;&#x76F8;&#x540C;&#x5206;&#x7247;&#x7684;&#x539F;&#x59CB;&#x6570;&#x636E;&#x548C;&#x526F;&#x672C;&#xFF0C;&#x90A3;&#x4E48;&#x5BF9;&#x8FD9;&#x4E2A;&#x5206;&#x7247;&#x5C06;&#x6CA1;&#x6709;&#x53EF;&#x7528;&#x526F;&#x672C;&#x6765;&#x5BF9;&#x641C;&#x7D22;&#x8BF7;&#x6C42;&#x4F5C;&#x51FA;&#x54CD;&#x5E94;&#x3002;&#x5047;&#x82E5;&#x8FD9;&#x6837;&#xFF0C;Elasticsearch &#x5C06;&#x62A5;&#x544A;&#x8FD9;&#x4E2A;&#x5206;&#x7247;&#x662F;&#x5931;&#x8D25;&#x7684;&#xFF0C;&#x4F46;&#x662F;&#x4F1A;&#x7EE7;&#x7EED;&#x8FD4;&#x56DE;&#x5269;&#x4F59;&#x5206;&#x7247;&#x7684;&#x7ED3;&#x679C;&#x3002;</p>
<p><strong>timeout</strong></p>
<p><code>timed_out</code> &#x503C;&#x544A;&#x8BC9;&#x6211;&#x4EEC;&#x67E5;&#x8BE2;&#x662F;&#x5426;&#x8D85;&#x65F6;&#x3002;&#x9ED8;&#x8BA4;&#x60C5;&#x51B5;&#x4E0B;&#xFF0C;&#x641C;&#x7D22;&#x8BF7;&#x6C42;&#x4E0D;&#x4F1A;&#x8D85;&#x65F6;&#x3002; &#x5982;&#x679C;&#x4F4E;&#x54CD;&#x5E94;&#x65F6;&#x95F4;&#x6BD4;&#x5B8C;&#x6210;&#x7ED3;&#x679C;&#x66F4;&#x91CD;&#x8981;&#xFF0C;&#x4F60;&#x53EF;&#x4EE5;&#x6307;&#x5B9A; <code>timeout</code> &#x4E3A; 10 &#x6216;&#x8005; 10ms&#xFF08;10&#x6BEB;&#x79D2;&#xFF09;&#xFF0C;&#x6216;&#x8005; 1s&#xFF08;1&#x79D2;&#xFF09;&#xFF1A;</p>
<pre><code class="lang-js">GET /_search?timeout=<span class="hljs-number">10</span>ms
</code></pre>
<p>&#x5728;&#x8BF7;&#x6C42;&#x8D85;&#x65F6;&#x4E4B;&#x524D;&#xFF0C;Elasticsearch &#x5C06;&#x4F1A;&#x8FD4;&#x56DE;&#x5DF2;&#x7ECF;&#x6210;&#x529F;&#x4ECE;&#x6BCF;&#x4E2A;&#x5206;&#x7247;&#x83B7;&#x53D6;&#x7684;&#x7ED3;&#x679C;&#x3002;</p>
<blockquote>
<p> <img src="assets/warning.png" alt="&#x8B66;&#x544A;">  &#x5E94;&#x5F53;&#x6CE8;&#x610F;&#x7684;&#x662F; <code>timeout</code> &#x4E0D;&#x662F;&#x505C;&#x6B62;&#x6267;&#x884C;&#x67E5;&#x8BE2;&#xFF0C;&#x5B83;&#x4EC5;&#x4EC5;&#x662F;&#x544A;&#x77E5;&#x6B63;&#x5728;&#x534F;&#x8C03;&#x7684;&#x8282;&#x70B9;&#x8FD4;&#x56DE;&#x5230;&#x76EE;&#x524D;&#x4E3A;&#x6B62;&#x6536;&#x96C6;&#x7684;&#x7ED3;&#x679C;&#x5E76;&#x4E14;&#x5173;&#x95ED;&#x8FDE;&#x63A5;&#x3002;&#x5728;&#x540E;&#x53F0;&#xFF0C;&#x5176;&#x4ED6;&#x7684;&#x5206;&#x7247;&#x53EF;&#x80FD;&#x4ECD;&#x5728;&#x6267;&#x884C;&#x67E5;&#x8BE2;&#x5373;&#x4F7F;&#x662F;&#x7ED3;&#x679C;&#x5DF2;&#x7ECF;&#x88AB;&#x53D1;&#x9001;&#x4E86;&#x3002;</p>
<p> &#x4F7F;&#x7528;&#x8D85;&#x65F6;&#x662F;&#x56E0;&#x4E3A; SLA(&#x670D;&#x52A1;&#x7B49;&#x7EA7;&#x534F;&#x8BAE;)&#x5BF9;&#x4F60;&#x662F;&#x5F88;&#x91CD;&#x8981;&#x7684;&#xFF0C;&#x800C;&#x4E0D;&#x662F;&#x56E0;&#x4E3A;&#x60F3;&#x53BB;&#x4E2D;&#x6B62;&#x957F;&#x65F6;&#x95F4;&#x8FD0;&#x884C;&#x7684;&#x67E5;&#x8BE2;&#x3002;</p>
</blockquote>
<h3 id="&#x591A;&#x7D22;&#x5F15;&#x591A;&#x7C7B;&#x578B;"><a name="&#x591A;&#x7D22;&#x5F15;&#x591A;&#x7C7B;&#x578B;" class="anchor-navigation-ex-anchor" href="#&#x591A;&#x7D22;&#x5F15;&#x591A;&#x7C7B;&#x578B;"><i class="fa fa-link" aria-hidden="true"></i></a>&#x591A;&#x7D22;&#x5F15;&#xFF0C;&#x591A;&#x7C7B;&#x578B;  </h3>
<p>&#x4F60;&#x6709;&#x6CA1;&#x6709;&#x6CE8;&#x610F;&#x5230;&#x4E4B;&#x524D;&#x7684; <a href="https://www.elastic.co/guide/cn/elasticsearch/guide/current/empty-search.html" target="_blank">empty search</a> &#x7684;&#x7ED3;&#x679C;&#xFF0C;&#x4E0D;&#x540C;&#x7C7B;&#x578B;&#x7684;&#x6587;&#x6863; &#x2014; <code>user</code> &#x548C; <code>tweet</code> &#x6765;&#x81EA;&#x4E0D;&#x540C;&#x7684;&#x7D22;&#x5F15;&#x2014; <code>us</code>&#x548C; <code>gb</code> &#xFF1F;</p>
<p>&#x5982;&#x679C;&#x4E0D;&#x5BF9;&#x67D0;&#x4E00;&#x7279;&#x6B8A;&#x7684;&#x7D22;&#x5F15;&#x6216;&#x8005;&#x7C7B;&#x578B;&#x505A;&#x9650;&#x5236;&#xFF0C;&#x5C31;&#x4F1A;&#x641C;&#x7D22;&#x96C6;&#x7FA4;&#x4E2D;&#x7684;&#x6240;&#x6709;&#x6587;&#x6863;&#x3002;Elasticsearch &#x8F6C;&#x53D1;&#x641C;&#x7D22;&#x8BF7;&#x6C42;&#x5230;&#x6BCF;&#x4E00;&#x4E2A;&#x4E3B;&#x5206;&#x7247;&#x6216;&#x8005;&#x526F;&#x672C;&#x5206;&#x7247;&#xFF0C;&#x6C47;&#x96C6;&#x67E5;&#x8BE2;&#x51FA;&#x7684;&#x524D;10&#x4E2A;&#x7ED3;&#x679C;&#xFF0C;&#x5E76;&#x4E14;&#x8FD4;&#x56DE;&#x7ED9;&#x6211;&#x4EEC;&#x3002;</p>
<p>&#x7136;&#x800C;&#xFF0C;&#x7ECF;&#x5E38;&#x7684;&#x60C5;&#x51B5;&#x4E0B;&#xFF0C;&#x4F60; &#x60F3;&#x5728;&#x4E00;&#x4E2A;&#x6216;&#x591A;&#x4E2A;&#x7279;&#x6B8A;&#x7684;&#x7D22;&#x5F15;&#x5E76;&#x4E14;&#x5728;&#x4E00;&#x4E2A;&#x6216;&#x8005;&#x591A;&#x4E2A;&#x7279;&#x6B8A;&#x7684;&#x7C7B;&#x578B;&#x4E2D;&#x8FDB;&#x884C;&#x641C;&#x7D22;&#x3002;&#x6211;&#x4EEC;&#x53EF;&#x4EE5;&#x901A;&#x8FC7;&#x5728;URL&#x4E2D;&#x6307;&#x5B9A;&#x7279;&#x6B8A;&#x7684;&#x7D22;&#x5F15;&#x548C;&#x7C7B;&#x578B;&#x8FBE;&#x5230;&#x8FD9;&#x79CD;&#x6548;&#x679C;&#xFF0C;&#x5982;&#x4E0B;&#x6240;&#x793A;&#xFF1A;</p>
<ul>
<li><p><code>/_search</code></p>
<p>&#x5728;&#x6240;&#x6709;&#x7684;&#x7D22;&#x5F15;&#x4E2D;&#x641C;&#x7D22;&#x6240;&#x6709;&#x7684;&#x7C7B;&#x578B;</p>
</li>
<li><p><code>/gb/_search</code></p>
<p>&#x5728; <code>gb</code> &#x7D22;&#x5F15;&#x4E2D;&#x641C;&#x7D22;&#x6240;&#x6709;&#x7684;&#x7C7B;&#x578B;</p>
</li>
<li><p><code>/gb,us/_search</code></p>
<p>&#x5728; <code>gb</code> &#x548C; <code>us</code> &#x7D22;&#x5F15;&#x4E2D;&#x641C;&#x7D22;&#x6240;&#x6709;&#x7684;&#x6587;&#x6863;</p>
</li>
<li><p><code>/g*,u*/_search</code></p>
<p>&#x5728;&#x4EFB;&#x4F55;&#x4EE5; <code>g</code> &#x6216;&#x8005; <code>u</code> &#x5F00;&#x5934;&#x7684;&#x7D22;&#x5F15;&#x4E2D;&#x641C;&#x7D22;&#x6240;&#x6709;&#x7684;&#x7C7B;&#x578B;</p>
</li>
<li><p><code>/gb/user/_search</code></p>
<p>&#x5728; <code>gb</code> &#x7D22;&#x5F15;&#x4E2D;&#x641C;&#x7D22; <code>user</code> &#x7C7B;&#x578B;</p>
</li>
<li><p><code>/gb,us/user,tweet/_search</code></p>
<p>&#x5728; <code>gb</code> &#x548C; <code>us</code> &#x7D22;&#x5F15;&#x4E2D;&#x641C;&#x7D22; <code>user</code> &#x548C; <code>tweet</code> &#x7C7B;&#x578B;</p>
</li>
<li><p><code>/_all/user,tweet/_search</code></p>
<p>&#x5728;&#x6240;&#x6709;&#x7684;&#x7D22;&#x5F15;&#x4E2D;&#x641C;&#x7D22; <code>user</code> &#x548C; <code>tweet</code> &#x7C7B;&#x578B;</p>
</li>
</ul>
<p>&#x5F53;&#x5728;&#x5355;&#x4E00;&#x7684;&#x7D22;&#x5F15;&#x4E0B;&#x8FDB;&#x884C;&#x641C;&#x7D22;&#x7684;&#x65F6;&#x5019;&#xFF0C;Elasticsearch &#x8F6C;&#x53D1;&#x8BF7;&#x6C42;&#x5230;&#x7D22;&#x5F15;&#x7684;&#x6BCF;&#x4E2A;&#x5206;&#x7247;&#x4E2D;&#xFF0C;&#x53EF;&#x4EE5;&#x662F;&#x4E3B;&#x5206;&#x7247;&#x4E5F;&#x53EF;&#x4EE5;&#x662F;&#x526F;&#x672C;&#x5206;&#x7247;&#xFF0C;&#x7136;&#x540E;&#x4ECE;&#x6BCF;&#x4E2A;&#x5206;&#x7247;&#x4E2D;&#x6536;&#x96C6;&#x7ED3;&#x679C;&#x3002;&#x591A;&#x7D22;&#x5F15;&#x641C;&#x7D22;&#x6070;&#x597D;&#x4E5F;&#x662F;&#x7528;&#x76F8;&#x540C;&#x7684;&#x65B9;&#x5F0F;&#x5DE5;&#x4F5C;&#x7684;--&#x53EA;&#x662F;&#x4F1A;&#x6D89;&#x53CA;&#x5230;&#x66F4;&#x591A;&#x7684;&#x5206;&#x7247;&#x3002;</p>
<blockquote>
<p> <img src="assets/tip.png" alt="&#x63D0;&#x793A;">  &#x641C;&#x7D22;&#x4E00;&#x4E2A;&#x7D22;&#x5F15;&#x6709;&#x4E94;&#x4E2A;&#x4E3B;&#x5206;&#x7247;&#x548C;&#x641C;&#x7D22;&#x4E94;&#x4E2A;&#x7D22;&#x5F15;&#x5404;&#x6709;&#x4E00;&#x4E2A;&#x5206;&#x7247;&#x51C6;&#x786E;&#x6765;&#x6240;&#x8BF4;&#x662F;&#x7B49;&#x4EF7;&#x7684;&#x3002;</p>
</blockquote>
<p>&#x63A5;&#x4E0B;&#x6765;&#xFF0C;&#x4F60;&#x5C06;&#x660E;&#x767D;&#x8FD9;&#x79CD;&#x7B80;&#x5355;&#x7684;&#x65B9;&#x5F0F;&#x5982;&#x4F55;&#x7075;&#x6D3B;&#x7684;&#x6839;&#x636E;&#x9700;&#x6C42;&#x7684;&#x53D8;&#x5316;&#x8BA9;&#x6269;&#x5BB9;&#x53D8;&#x5F97;&#x7B80;&#x5355;&#x3002;</p>
<h3 id="&#x5206;&#x9875;"><a name="&#x5206;&#x9875;" class="anchor-navigation-ex-anchor" href="#&#x5206;&#x9875;"><i class="fa fa-link" aria-hidden="true"></i></a>&#x5206;&#x9875;</h3>
<p>&#x5728;&#x4E4B;&#x524D;&#x7684; <a href="https://www.elastic.co/guide/cn/elasticsearch/guide/current/empty-search.html" target="_blank">&#x7A7A;&#x641C;&#x7D22;</a> &#x4E2D;&#x8BF4;&#x660E;&#x4E86;&#x96C6;&#x7FA4;&#x4E2D;&#x6709; 14 &#x4E2A;&#x6587;&#x6863;&#x5339;&#x914D;&#x4E86;&#xFF08;empty&#xFF09;query &#x3002; &#x4F46;&#x662F;&#x5728; <code>hits</code> &#x6570;&#x7EC4;&#x4E2D;&#x53EA;&#x6709; 10 &#x4E2A;&#x6587;&#x6863;&#x3002;&#x5982;&#x4F55;&#x624D;&#x80FD;&#x770B;&#x5230;&#x5176;&#x4ED6;&#x7684;&#x6587;&#x6863;&#xFF1F;</p>
<p>&#x548C; SQL &#x4F7F;&#x7528; <code>LIMIT</code> &#x5173;&#x952E;&#x5B57;&#x8FD4;&#x56DE;&#x5355;&#x4E2A; <code>page</code> &#x7ED3;&#x679C;&#x7684;&#x65B9;&#x6CD5;&#x76F8;&#x540C;&#xFF0C;Elasticsearch &#x63A5;&#x53D7; <code>from</code> &#x548C; <code>size</code> &#x53C2;&#x6570;&#xFF1A;</p>
<ul>
<li><p><code>size</code></p>
<p>&#x663E;&#x793A;&#x5E94;&#x8BE5;&#x8FD4;&#x56DE;&#x7684;&#x7ED3;&#x679C;&#x6570;&#x91CF;&#xFF0C;&#x9ED8;&#x8BA4;&#x662F; <code>10</code></p>
</li>
<li><p><code>from</code></p>
<p>&#x663E;&#x793A;&#x5E94;&#x8BE5;&#x8DF3;&#x8FC7;&#x7684;&#x521D;&#x59CB;&#x7ED3;&#x679C;&#x6570;&#x91CF;&#xFF0C;&#x9ED8;&#x8BA4;&#x662F; <code>0</code></p>
</li>
</ul>
<p>&#x5982;&#x679C;&#x6BCF;&#x9875;&#x5C55;&#x793A; 5 &#x6761;&#x7ED3;&#x679C;&#xFF0C;&#x53EF;&#x4EE5;&#x7528;&#x4E0B;&#x9762;&#x65B9;&#x5F0F;&#x8BF7;&#x6C42;&#x5F97;&#x5230; 1 &#x5230; 3 &#x9875;&#x7684;&#x7ED3;&#x679C;&#xFF1A;</p>
<pre><code class="lang-js">GET /_search?size=<span class="hljs-number">5</span>
GET /_search?size=<span class="hljs-number">5</span>&amp;<span class="hljs-keyword">from</span>=<span class="hljs-number">5</span>
GET /_search?size=<span class="hljs-number">5</span>&amp;<span class="hljs-keyword">from</span>=<span class="hljs-number">10</span>
</code></pre>
<p>&#x8003;&#x8651;&#x5230;&#x5206;&#x9875;&#x8FC7;&#x6DF1;&#x4EE5;&#x53CA;&#x4E00;&#x6B21;&#x8BF7;&#x6C42;&#x592A;&#x591A;&#x7ED3;&#x679C;&#x7684;&#x60C5;&#x51B5;&#xFF0C;&#x7ED3;&#x679C;&#x96C6;&#x5728;&#x8FD4;&#x56DE;&#x4E4B;&#x524D;&#x5148;&#x8FDB;&#x884C;&#x6392;&#x5E8F;&#x3002; &#x4F46;&#x8BF7;&#x8BB0;&#x4F4F;&#x4E00;&#x4E2A;&#x8BF7;&#x6C42;&#x7ECF;&#x5E38;&#x8DE8;&#x8D8A;&#x591A;&#x4E2A;&#x5206;&#x7247;&#xFF0C;&#x6BCF;&#x4E2A;&#x5206;&#x7247;&#x90FD;&#x4EA7;&#x751F;&#x81EA;&#x5DF1;&#x7684;&#x6392;&#x5E8F;&#x7ED3;&#x679C;&#xFF0C;&#x8FD9;&#x4E9B;&#x7ED3;&#x679C;&#x9700;&#x8981;&#x8FDB;&#x884C;&#x96C6;&#x4E2D;&#x6392;&#x5E8F;&#x4EE5;&#x4FDD;&#x8BC1;&#x6574;&#x4F53;&#x987A;&#x5E8F;&#x662F;&#x6B63;&#x786E;&#x7684;&#x3002;</p>
<hr>
<blockquote>
<p> <strong>&#x5728;&#x5206;&#x5E03;&#x5F0F;&#x7CFB;&#x7EDF;&#x4E2D;&#x6DF1;&#x5EA6;&#x5206;&#x9875;</strong></p>
<p> &#x7406;&#x89E3;&#x4E3A;&#x4EC0;&#x4E48;&#x6DF1;&#x5EA6;&#x5206;&#x9875;&#x662F;&#x6709;&#x95EE;&#x9898;&#x7684;&#xFF0C;&#x6211;&#x4EEC;&#x53EF;&#x4EE5;&#x5047;&#x8BBE;&#x5728;&#x4E00;&#x4E2A;&#x6709; 5 &#x4E2A;&#x4E3B;&#x5206;&#x7247;&#x7684;&#x7D22;&#x5F15;&#x4E2D;&#x641C;&#x7D22;&#x3002; &#x5F53;&#x6211;&#x4EEC;&#x8BF7;&#x6C42;&#x7ED3;&#x679C;&#x7684;&#x7B2C;&#x4E00;&#x9875;&#xFF08;&#x7ED3;&#x679C;&#x4ECE; 1 &#x5230; 10 &#xFF09;&#xFF0C;&#x6BCF;&#x4E00;&#x4E2A;&#x5206;&#x7247;&#x4EA7;&#x751F;&#x524D; 10 &#x7684;&#x7ED3;&#x679C;&#xFF0C;&#x5E76;&#x4E14;&#x8FD4;&#x56DE;&#x7ED9; <em>&#x534F;&#x8C03;&#x8282;&#x70B9;</em> &#xFF0C;&#x534F;&#x8C03;&#x8282;&#x70B9;&#x5BF9; 50 &#x4E2A;&#x7ED3;&#x679C;&#x6392;&#x5E8F;&#x5F97;&#x5230;&#x5168;&#x90E8;&#x7ED3;&#x679C;&#x7684;&#x524D; 10 &#x4E2A;&#x3002;</p>
<p> &#x73B0;&#x5728;&#x5047;&#x8BBE;&#x6211;&#x4EEC;&#x8BF7;&#x6C42;&#x7B2C; 1000 &#x9875;--&#x7ED3;&#x679C;&#x4ECE; 10001 &#x5230; 10010 &#x3002;&#x6240;&#x6709;&#x90FD;&#x4EE5;&#x76F8;&#x540C;&#x7684;&#x65B9;&#x5F0F;&#x5DE5;&#x4F5C;&#x9664;&#x4E86;&#x6BCF;&#x4E2A;&#x5206;&#x7247;&#x4E0D;&#x5F97;&#x4E0D;&#x4EA7;&#x751F;&#x524D;10010&#x4E2A;&#x7ED3;&#x679C;&#x4EE5;&#x5916;&#x3002; &#x7136;&#x540E;&#x534F;&#x8C03;&#x8282;&#x70B9;&#x5BF9;&#x5168;&#x90E8; 50050 &#x4E2A;&#x7ED3;&#x679C;&#x6392;&#x5E8F;&#x6700;&#x540E;&#x4E22;&#x5F03;&#x6389;&#x8FD9;&#x4E9B;&#x7ED3;&#x679C;&#x4E2D;&#x7684; 50040 &#x4E2A;&#x7ED3;&#x679C;&#x3002;</p>
<p> &#x53EF;&#x4EE5;&#x770B;&#x5230;&#xFF0C;&#x5728;&#x5206;&#x5E03;&#x5F0F;&#x7CFB;&#x7EDF;&#x4E2D;&#xFF0C;&#x5BF9;&#x7ED3;&#x679C;&#x6392;&#x5E8F;&#x7684;&#x6210;&#x672C;&#x968F;&#x5206;&#x9875;&#x7684;&#x6DF1;&#x5EA6;&#x6210;&#x6307;&#x6570;&#x4E0A;&#x5347;&#x3002;&#x8FD9;&#x5C31;&#x662F; web &#x641C;&#x7D22;&#x5F15;&#x64CE;&#x5BF9;&#x4EFB;&#x4F55;&#x67E5;&#x8BE2;&#x90FD;&#x4E0D;&#x8981;&#x8FD4;&#x56DE;&#x8D85;&#x8FC7; 1000 &#x4E2A;&#x7ED3;&#x679C;&#x7684;&#x539F;&#x56E0;&#x3002;</p>
</blockquote>
<hr>
<blockquote>
<p> <img src="assets/tip.png" alt="&#x63D0;&#x793A;">  &#x5728; <a href="https://www.elastic.co/guide/cn/elasticsearch/guide/current/reindex.html" target="_blank">&#x91CD;&#x65B0;&#x7D22;&#x5F15;&#x4F60;&#x7684;&#x6570;&#x636E;</a> &#x4E2D;&#x89E3;&#x91CA;&#x4E86;&#x5982;&#x4F55; <em>&#x80FD;&#x591F;</em> &#x6709;&#x6548;&#x83B7;&#x53D6;&#x5927;&#x91CF;&#x7684;&#x6587;&#x6863;&#x3002;</p>
</blockquote>
<h3 id="&#x8F7B;&#x91CF;&#x641C;&#x7D22;"><a name="&#x8F7B;&#x91CF;&#x641C;&#x7D22;" class="anchor-navigation-ex-anchor" href="#&#x8F7B;&#x91CF;&#x641C;&#x7D22;"><i class="fa fa-link" aria-hidden="true"></i></a>&#x8F7B;&#x91CF;&#x641C;&#x7D22;</h3>
<p>&#x6709;&#x4E24;&#x79CD;&#x5F62;&#x5F0F;&#x7684; <code>&#x641C;&#x7D22;</code> API&#xFF1A;&#x4E00;&#x79CD;&#x662F; &#x201C;&#x8F7B;&#x91CF;&#x7684;&#x201D; <em>&#x67E5;&#x8BE2;&#x5B57;&#x7B26;&#x4E32;</em> &#x7248;&#x672C;&#xFF0C;&#x8981;&#x6C42;&#x5728;&#x67E5;&#x8BE2;&#x5B57;&#x7B26;&#x4E32;&#x4E2D;&#x4F20;&#x9012;&#x6240;&#x6709;&#x7684; &#x53C2;&#x6570;&#xFF0C;&#x53E6;&#x4E00;&#x79CD;&#x662F;&#x66F4;&#x5B8C;&#x6574;&#x7684; <em>&#x8BF7;&#x6C42;&#x4F53;</em> &#x7248;&#x672C;&#xFF0C;&#x8981;&#x6C42;&#x4F7F;&#x7528; JSON &#x683C;&#x5F0F;&#x548C;&#x66F4;&#x4E30;&#x5BCC;&#x7684;&#x67E5;&#x8BE2;&#x8868;&#x8FBE;&#x5F0F;&#x4F5C;&#x4E3A;&#x641C;&#x7D22;&#x8BED;&#x8A00;&#x3002;</p>
<p>&#x67E5;&#x8BE2;&#x5B57;&#x7B26;&#x4E32;&#x641C;&#x7D22;&#x975E;&#x5E38;&#x9002;&#x7528;&#x4E8E;&#x901A;&#x8FC7;&#x547D;&#x4EE4;&#x884C;&#x505A;&#x5373;&#x5E2D;&#x67E5;&#x8BE2;&#x3002;&#x4F8B;&#x5982;&#xFF0C;&#x67E5;&#x8BE2;&#x5728; <code>tweet</code> &#x7C7B;&#x578B;&#x4E2D; <code>tweet</code> &#x5B57;&#x6BB5;&#x5305;&#x542B; <code>elasticsearch</code> &#x5355;&#x8BCD;&#x7684;&#x6240;&#x6709;&#x6587;&#x6863;&#xFF1A;</p>
<pre><code class="lang-js">GET /_all/tweet/_search?q=tweet:elasticsearch
</code></pre>
<p>&#x62F7;&#x8D1D;&#x4E3A; CURL<a href="http://localhost:5601/app/sense/?load_from=https://www.elastic.co/guide/cn/elasticsearch/guide/current/snippets/050_Search/20_Query_string.json" target="_blank">&#x5728; SENSE &#x4E2D;&#x67E5;&#x770B;</a> </p>
<p>&#x4E0B;&#x4E00;&#x4E2A;&#x67E5;&#x8BE2;&#x5728; <code>name</code> &#x5B57;&#x6BB5;&#x4E2D;&#x5305;&#x542B; <code>john</code> &#x5E76;&#x4E14;&#x5728; <code>tweet</code> &#x5B57;&#x6BB5;&#x4E2D;&#x5305;&#x542B; <code>mary</code> &#x7684;&#x6587;&#x6863;&#x3002;&#x5B9E;&#x9645;&#x7684;&#x67E5;&#x8BE2;&#x5C31;&#x662F;&#x8FD9;&#x6837;</p>
<pre><code>+name:john +tweet:mary
</code></pre><p>&#x4F46;&#x662F;&#x67E5;&#x8BE2;&#x5B57;&#x7B26;&#x4E32;&#x53C2;&#x6570;&#x6240;&#x9700;&#x8981;&#x7684; <em>&#x767E;&#x5206;&#x6BD4;&#x7F16;&#x7801;</em> &#xFF08;&#x8BD1;&#x8005;&#x6CE8;&#xFF1A;URL&#x7F16;&#x7801;&#xFF09;&#x5B9E;&#x9645;&#x4E0A;&#x66F4;&#x52A0;&#x96BE;&#x61C2;&#xFF1A;</p>
<pre><code class="lang-js">GET /_search?q=%<span class="hljs-number">2</span>Bname%<span class="hljs-number">3</span>Ajohn+%<span class="hljs-number">2</span>Btweet%<span class="hljs-number">3</span>Amary
</code></pre>
<p>&#x62F7;&#x8D1D;&#x4E3A; CURL<a href="http://localhost:5601/app/sense/?load_from=https://www.elastic.co/guide/cn/elasticsearch/guide/current/snippets/050_Search/20_Query_string.json" target="_blank">&#x5728; SENSE &#x4E2D;&#x67E5;&#x770B;</a> </p>
<p><code>+</code> &#x524D;&#x7F00;&#x8868;&#x793A;&#x5FC5;&#x987B;&#x4E0E;&#x67E5;&#x8BE2;&#x6761;&#x4EF6;&#x5339;&#x914D;&#x3002;&#x7C7B;&#x4F3C;&#x5730;&#xFF0C; <code>-</code> &#x524D;&#x7F00;&#x8868;&#x793A;&#x4E00;&#x5B9A;&#x4E0D;&#x4E0E;&#x67E5;&#x8BE2;&#x6761;&#x4EF6;&#x5339;&#x914D;&#x3002;&#x6CA1;&#x6709; <code>+</code> &#x6216;&#x8005; <code>-</code> &#x7684;&#x6240;&#x6709;&#x5176;&#x4ED6;&#x6761;&#x4EF6;&#x90FD;&#x662F;&#x53EF;&#x9009;&#x7684;&#x2014;&#x2014;&#x5339;&#x914D;&#x7684;&#x8D8A;&#x591A;&#xFF0C;&#x6587;&#x6863;&#x5C31;&#x8D8A;&#x76F8;&#x5173;&#x3002;</p>
<p><strong>_all &#x5B57;&#x6BB5;</strong></p>
<p>&#x8FD9;&#x4E2A;&#x7B80;&#x5355;&#x641C;&#x7D22;&#x8FD4;&#x56DE;&#x5305;&#x542B; <code>mary</code> &#x7684;&#x6240;&#x6709;&#x6587;&#x6863;&#xFF1A;</p>
<pre><code class="lang-js">GET /_search?q=mary
</code></pre>
<p>&#x62F7;&#x8D1D;&#x4E3A; CURL<a href="http://localhost:5601/app/sense/?load_from=https://www.elastic.co/guide/cn/elasticsearch/guide/current/snippets/050_Search/20_All_field.json" target="_blank">&#x5728; SENSE &#x4E2D;&#x67E5;&#x770B;</a> </p>
<p>&#x4E4B;&#x524D;&#x7684;&#x4F8B;&#x5B50;&#x4E2D;&#xFF0C;&#x6211;&#x4EEC;&#x5728; <code>tweet</code> &#x548C; <code>name</code> &#x5B57;&#x6BB5;&#x4E2D;&#x641C;&#x7D22;&#x5185;&#x5BB9;&#x3002;&#x7136;&#x800C;&#xFF0C;&#x8FD9;&#x4E2A;&#x67E5;&#x8BE2;&#x7684;&#x7ED3;&#x679C;&#x5728;&#x4E09;&#x4E2A;&#x5730;&#x65B9;&#x63D0;&#x5230;&#x4E86; <code>mary</code>&#xFF1A;</p>
<ul>
<li>&#x6709;&#x4E00;&#x4E2A;&#x7528;&#x6237;&#x53EB;&#x505A; Mary</li>
<li>6&#x6761;&#x5FAE;&#x535A;&#x53D1;&#x81EA; Mary</li>
<li>&#x4E00;&#x6761;&#x5FAE;&#x535A;&#x76F4;&#x63A5; @mary</li>
</ul>
<p>Elasticsearch &#x662F;&#x5982;&#x4F55;&#x5728;&#x4E09;&#x4E2A;&#x4E0D;&#x540C;&#x7684;&#x5B57;&#x6BB5;&#x4E2D;&#x67E5;&#x627E;&#x5230;&#x7ED3;&#x679C;&#x7684;&#x5462;&#xFF1F;</p>
<p>&#x5F53;&#x7D22;&#x5F15;&#x4E00;&#x4E2A;&#x6587;&#x6863;&#x7684;&#x65F6;&#x5019;&#xFF0C;Elasticsearch &#x53D6;&#x51FA;&#x6240;&#x6709;&#x5B57;&#x6BB5;&#x7684;&#x503C;&#x62FC;&#x63A5;&#x6210;&#x4E00;&#x4E2A;&#x5927;&#x7684;&#x5B57;&#x7B26;&#x4E32;&#xFF0C;&#x4F5C;&#x4E3A; <code>_all</code> &#x5B57;&#x6BB5;&#x8FDB;&#x884C;&#x7D22;&#x5F15;&#x3002;&#x4F8B;&#x5982;&#xFF0C;&#x5F53;&#x7D22;&#x5F15;&#x8FD9;&#x4E2A;&#x6587;&#x6863;&#x65F6;&#xFF1A;</p>
<pre><code class="lang-js">{
    <span class="hljs-string">&quot;tweet&quot;</span>:    <span class="hljs-string">&quot;However did I manage before Elasticsearch?&quot;</span>,
    <span class="hljs-string">&quot;date&quot;</span>:     <span class="hljs-string">&quot;2014-09-14&quot;</span>,
    <span class="hljs-string">&quot;name&quot;</span>:     <span class="hljs-string">&quot;Mary Jones&quot;</span>,
    <span class="hljs-string">&quot;user_id&quot;</span>:  <span class="hljs-number">1</span>
}
</code></pre>
<p>&#x8FD9;&#x5C31;&#x597D;&#x4F3C;&#x589E;&#x52A0;&#x4E86;&#x4E00;&#x4E2A;&#x540D;&#x53EB; <code>_all</code> &#x7684;&#x989D;&#x5916;&#x5B57;&#x6BB5;&#xFF1A;</p>
<pre><code class="lang-js"><span class="hljs-string">&quot;However did I manage before Elasticsearch? 2014-09-14 Mary Jones 1&quot;</span>
</code></pre>
<p>&#x9664;&#x975E;&#x8BBE;&#x7F6E;&#x7279;&#x5B9A;&#x5B57;&#x6BB5;&#xFF0C;&#x5426;&#x5219;&#x67E5;&#x8BE2;&#x5B57;&#x7B26;&#x4E32;&#x5C31;&#x4F7F;&#x7528; <code>_all</code> &#x5B57;&#x6BB5;&#x8FDB;&#x884C;&#x641C;&#x7D22;&#x3002;</p>
<blockquote>
<p> <img src="assets/tip.png" alt="&#x63D0;&#x793A;">  &#x5728;&#x521A;&#x5F00;&#x59CB;&#x5F00;&#x53D1;&#x4E00;&#x4E2A;&#x5E94;&#x7528;&#x65F6;&#xFF0C;<code>_all</code> &#x5B57;&#x6BB5;&#x662F;&#x4E00;&#x4E2A;&#x5F88;&#x5B9E;&#x7528;&#x7684;&#x7279;&#x6027;&#x3002;&#x4E4B;&#x540E;&#xFF0C;&#x4F60;&#x4F1A;&#x53D1;&#x73B0;&#x5982;&#x679C;&#x641C;&#x7D22;&#x65F6;&#x7528;&#x6307;&#x5B9A;&#x5B57;&#x6BB5;&#x6765;&#x4EE3;&#x66FF; <code>_all</code> &#x5B57;&#x6BB5;&#xFF0C;&#x5C06;&#x4F1A;&#x66F4;&#x597D;&#x63A7;&#x5236;&#x641C;&#x7D22;&#x7ED3;&#x679C;&#x3002;&#x5F53; <code>_all</code> &#x5B57;&#x6BB5;&#x4E0D;&#x518D;&#x6709;&#x7528;&#x7684;&#x65F6;&#x5019;&#xFF0C;&#x53EF;&#x4EE5;&#x5C06;&#x5B83;&#x7F6E;&#x4E3A;&#x5931;&#x6548;&#xFF0C;&#x6B63;&#x5982;&#x5728; <a href="https://www.elastic.co/guide/cn/elasticsearch/guide/current/root-object.html#all-field" target="_blank">&#x5143;&#x6570;&#x636E;: _all &#x5B57;&#x6BB5;</a> &#x4E2D;&#x6240;&#x89E3;&#x91CA;&#x7684;&#x3002;</p>
</blockquote>
<p><strong>&#x66F4;&#x590D;&#x6742;&#x7684;&#x67E5;&#x8BE2;</strong></p>
<p>&#x4E0B;&#x9762;&#x7684;&#x67E5;&#x8BE2;&#x9488;&#x5BF9;tweents&#x7C7B;&#x578B;&#xFF0C;&#x5E76;&#x4F7F;&#x7528;&#x4EE5;&#x4E0B;&#x7684;&#x6761;&#x4EF6;&#xFF1A;</p>
<ul>
<li><code>name</code> &#x5B57;&#x6BB5;&#x4E2D;&#x5305;&#x542B; <code>mary</code> &#x6216;&#x8005; <code>john</code></li>
<li><code>date</code> &#x503C;&#x5927;&#x4E8E; <code>2014-09-10</code></li>
<li><code>_all</code> &#x5B57;&#x6BB5;&#x5305;&#x542B; <code>aggregations</code> &#x6216;&#x8005; <code>geo</code></li>
</ul>
<pre><code class="lang-js">+name:(mary john) +date:&gt;<span class="hljs-number">2014</span><span class="hljs-number">-09</span><span class="hljs-number">-10</span> +(aggregations geo)
</code></pre>
<p>&#x62F7;&#x8D1D;&#x4E3A; CURL<a href="http://localhost:5601/app/sense/?load_from=https://www.elastic.co/guide/cn/elasticsearch/guide/current/snippets/050_Search/20_All_field.json" target="_blank">&#x5728; SENSE &#x4E2D;&#x67E5;&#x770B;</a> </p>
<p>&#x67E5;&#x8BE2;&#x5B57;&#x7B26;&#x4E32;&#x5728;&#x505A;&#x4E86;&#x9002;&#x5F53;&#x7684;&#x7F16;&#x7801;&#x540E;&#xFF0C;&#x53EF;&#x8BFB;&#x6027;&#x5F88;&#x5DEE;&#xFF1A;</p>
<pre><code class="lang-js">?q=%<span class="hljs-number">2</span>Bname%<span class="hljs-number">3</span>A(mary+john)+%<span class="hljs-number">2</span>Bdate%<span class="hljs-number">3</span>A%<span class="hljs-number">3E2014</span><span class="hljs-number">-09</span><span class="hljs-number">-10</span>+%<span class="hljs-number">2</span>B(aggregations+geo)
</code></pre>
<p>&#x4ECE;&#x4E4B;&#x524D;&#x7684;&#x4F8B;&#x5B50;&#x4E2D;&#x53EF;&#x4EE5;&#x770B;&#x51FA;&#xFF0C;&#x8FD9;&#x79CD; <em>&#x8F7B;&#x91CF;</em> &#x7684;&#x67E5;&#x8BE2;&#x5B57;&#x7B26;&#x4E32;&#x641C;&#x7D22;&#x6548;&#x679C;&#x8FD8;&#x662F;&#x633A;&#x8BA9;&#x4EBA;&#x60CA;&#x559C;&#x7684;&#x3002; &#x5B83;&#x7684;&#x67E5;&#x8BE2;&#x8BED;&#x6CD5;&#x5728;&#x76F8;&#x5173;&#x53C2;&#x8003;&#x6587;&#x6863;&#x4E2D;&#x6709;&#x8BE6;&#x7EC6;&#x89E3;&#x91CA;&#xFF0C;&#x4EE5;&#x4FBF;&#x7B80;&#x6D01;&#x7684;&#x8868;&#x8FBE;&#x5F88;&#x590D;&#x6742;&#x7684;&#x67E5;&#x8BE2;&#x3002;&#x5BF9;&#x4E8E;&#x901A;&#x8FC7;&#x547D;&#x4EE4;&#x505A;&#x4E00;&#x6B21;&#x6027;&#x67E5;&#x8BE2;&#xFF0C;&#x6216;&#x8005;&#x662F;&#x5728;&#x5F00;&#x53D1;&#x9636;&#x6BB5;&#xFF0C;&#x90FD;&#x975E;&#x5E38;&#x65B9;&#x4FBF;&#x3002;</p>
<p>&#x4F46;&#x540C;&#x65F6;&#x4E5F;&#x53EF;&#x4EE5;&#x770B;&#x5230;&#xFF0C;&#x8FD9;&#x79CD;&#x7CBE;&#x7B80;&#x8BA9;&#x8C03;&#x8BD5;&#x66F4;&#x52A0;&#x6666;&#x6DA9;&#x548C;&#x56F0;&#x96BE;&#x3002;&#x800C;&#x4E14;&#x5F88;&#x8106;&#x5F31;&#xFF0C;&#x4E00;&#x4E9B;&#x67E5;&#x8BE2;&#x5B57;&#x7B26;&#x4E32;&#x4E2D;&#x5F88;&#x5C0F;&#x7684;&#x8BED;&#x6CD5;&#x9519;&#x8BEF;&#xFF0C;&#x50CF; <code>-</code> &#xFF0C; <code>:</code> &#xFF0C; <code>/</code> &#x6216;&#x8005; <code>&quot;</code> &#x4E0D;&#x5339;&#x914D;&#x7B49;&#xFF0C;&#x5C06;&#x4F1A;&#x8FD4;&#x56DE;&#x9519;&#x8BEF;&#x800C;&#x4E0D;&#x662F;&#x641C;&#x7D22;&#x7ED3;&#x679C;&#x3002;</p>
<p>&#x6700;&#x540E;&#xFF0C;&#x67E5;&#x8BE2;&#x5B57;&#x7B26;&#x4E32;&#x641C;&#x7D22;&#x5141;&#x8BB8;&#x4EFB;&#x4F55;&#x7528;&#x6237;&#x5728;&#x7D22;&#x5F15;&#x7684;&#x4EFB;&#x610F;&#x5B57;&#x6BB5;&#x4E0A;&#x6267;&#x884C;&#x53EF;&#x80FD;&#x8F83;&#x6162;&#x4E14;&#x91CD;&#x91CF;&#x7EA7;&#x7684;&#x67E5;&#x8BE2;&#xFF0C;&#x8FD9;&#x53EF;&#x80FD;&#x4F1A;&#x66B4;&#x9732;&#x9690;&#x79C1;&#x4FE1;&#x606F;&#xFF0C;&#x751A;&#x81F3;&#x5C06;&#x96C6;&#x7FA4;&#x62D6;&#x57AE;&#x3002;</p>
<blockquote>
<p> <img src="assets/tip.png" alt="&#x63D0;&#x793A;">  &#x56E0;&#x4E3A;&#x8FD9;&#x4E9B;&#x539F;&#x56E0;&#xFF0C;&#x4E0D;&#x63A8;&#x8350;&#x76F4;&#x63A5;&#x5411;&#x7528;&#x6237;&#x66B4;&#x9732;&#x67E5;&#x8BE2;&#x5B57;&#x7B26;&#x4E32;&#x641C;&#x7D22;&#x529F;&#x80FD;&#xFF0C;&#x9664;&#x975E;&#x5BF9;&#x4E8E;&#x96C6;&#x7FA4;&#x548C;&#x6570;&#x636E;&#x6765;&#x8BF4;&#x975E;&#x5E38;&#x4FE1;&#x4EFB;&#x4ED6;&#x4EEC;&#x3002;</p>
</blockquote>
<p>&#x76F8;&#x53CD;&#xFF0C;&#x6211;&#x4EEC;&#x7ECF;&#x5E38;&#x5728;&#x751F;&#x4EA7;&#x73AF;&#x5883;&#x4E2D;&#x66F4;&#x591A;&#x5730;&#x4F7F;&#x7528;&#x529F;&#x80FD;&#x5168;&#x9762;&#x7684; <em>request body</em> &#x67E5;&#x8BE2;API&#xFF0C;&#x9664;&#x4E86;&#x80FD;&#x5B8C;&#x6210;&#x4EE5;&#x4E0A;&#x6240;&#x6709;&#x529F;&#x80FD;&#xFF0C;&#x8FD8;&#x6709;&#x4E00;&#x4E9B;&#x9644;&#x52A0;&#x529F;&#x80FD;&#x3002;&#x4F46;&#x5728;&#x5230;&#x8FBE;&#x90A3;&#x4E2A;&#x9636;&#x6BB5;&#x4E4B;&#x524D;&#xFF0C;&#x9996;&#x5148;&#x9700;&#x8981;&#x4E86;&#x89E3;&#x6570;&#x636E;&#x5728; Elasticsearch &#x4E2D;&#x662F;&#x5982;&#x4F55;&#x88AB;&#x7D22;&#x5F15;&#x7684;&#x3002;</p>
<h2 id="&#x6620;&#x5C04;&#x548C;&#x5206;&#x6790;"><a name="&#x6620;&#x5C04;&#x548C;&#x5206;&#x6790;" class="anchor-navigation-ex-anchor" href="#&#x6620;&#x5C04;&#x548C;&#x5206;&#x6790;"><i class="fa fa-link" aria-hidden="true"></i></a>&#x6620;&#x5C04;&#x548C;&#x5206;&#x6790;</h2>
<p>&#x5F53;&#x6446;&#x5F04;&#x7D22;&#x5F15;&#x91CC;&#x9762;&#x7684;&#x6570;&#x636E;&#x65F6;&#xFF0C;&#x6211;&#x4EEC;&#x53D1;&#x73B0;&#x4E00;&#x4E9B;&#x5947;&#x602A;&#x7684;&#x4E8B;&#x60C5;&#x3002;&#x4E00;&#x4E9B;&#x4E8B;&#x60C5;&#x770B;&#x8D77;&#x6765;&#x88AB;&#x6253;&#x4E71;&#x4E86;&#xFF1A;&#x5728;&#x6211;&#x4EEC;&#x7684;&#x7D22;&#x5F15;&#x4E2D;&#x6709;12&#x6761;&#x63A8;&#x6587;&#xFF0C;&#x5176;&#x4E2D;&#x53EA;&#x6709;&#x4E00;&#x6761;&#x5305;&#x542B;&#x65E5;&#x671F; <code>2014-09-15</code> &#xFF0C;&#x4F46;&#x662F;&#x770B;&#x4E00;&#x770B;&#x4E0B;&#x9762;&#x67E5;&#x8BE2;&#x547D;&#x4E2D;&#x7684; <code>&#x603B;&#x6570;</code> &#xFF08;total&#xFF09;&#xFF1A;</p>
<pre><code class="lang-js">GET /_search?q=2014              # 12 results
GET /_search?q=2014-09-15        # 12 results !
GET /_search?q=date:2014-09-15   # 1  result
GET /_search?q=date:2014         # 0  results !
</code></pre>
<p>&#x4E3A;&#x4EC0;&#x4E48;&#x5728; <a href="https://www.elastic.co/guide/cn/elasticsearch/guide/current/search-lite.html#all-field-intro" target="_blank"><code>_all</code></a> &#x5B57;&#x6BB5;&#x67E5;&#x8BE2;&#x65E5;&#x671F;&#x8FD4;&#x56DE;&#x6240;&#x6709;&#x63A8;&#x6587;&#xFF0C;&#x800C;&#x5728; <code>date</code> &#x5B57;&#x6BB5;&#x53EA;&#x67E5;&#x8BE2;&#x5E74;&#x4EFD;&#x5374;&#x6CA1;&#x6709;&#x8FD4;&#x56DE;&#x7ED3;&#x679C;&#xFF1F;&#x4E3A;&#x4EC0;&#x4E48;&#x6211;&#x4EEC;&#x5728; <code>_all</code> &#x5B57;&#x6BB5;&#x548C; <code>date</code> &#x5B57;&#x6BB5;&#x7684;&#x67E5;&#x8BE2;&#x7ED3;&#x679C;&#x6709;&#x5DEE;&#x522B;&#xFF1F;</p>
<p>&#x63A8;&#x6D4B;&#x8D77;&#x6765;&#xFF0C;&#x8FD9;&#x662F;&#x56E0;&#x4E3A;&#x6570;&#x636E;&#x5728; <code>_all</code> &#x5B57;&#x6BB5;&#x4E0E; <code>date</code> &#x5B57;&#x6BB5;&#x7684;&#x7D22;&#x5F15;&#x65B9;&#x5F0F;&#x4E0D;&#x540C;&#x3002;&#x6240;&#x4EE5;&#xFF0C;&#x901A;&#x8FC7;&#x8BF7;&#x6C42; <code>gb</code> &#x7D22;&#x5F15;&#x4E2D; <code>tweet</code>&#x7C7B;&#x578B;&#x7684;<em>&#x6620;&#x5C04;</em>&#xFF08;&#x6216;&#x6A21;&#x5F0F;&#x5B9A;&#x4E49;&#xFF09;&#xFF0C;&#x8BA9;&#x6211;&#x4EEC;&#x770B;&#x4E00;&#x770B; Elasticsearch &#x662F;&#x5982;&#x4F55;&#x89E3;&#x91CA;&#x6211;&#x4EEC;&#x6587;&#x6863;&#x7ED3;&#x6784;&#x7684;&#xFF1A;</p>
<pre><code class="lang-js">GET /gb/_mapping/tweet
</code></pre>
<p>&#x8FD9;&#x5C06;&#x5F97;&#x5230;&#x5982;&#x4E0B;&#x7ED3;&#x679C;&#xFF1A;</p>
<pre><code class="lang-js">{
   <span class="hljs-string">&quot;gb&quot;</span>: {
      <span class="hljs-string">&quot;mappings&quot;</span>: {
         <span class="hljs-string">&quot;tweet&quot;</span>: {
            <span class="hljs-string">&quot;properties&quot;</span>: {
               <span class="hljs-string">&quot;date&quot;</span>: {
                  <span class="hljs-string">&quot;type&quot;</span>: <span class="hljs-string">&quot;date&quot;</span>,
                  <span class="hljs-string">&quot;format&quot;</span>: <span class="hljs-string">&quot;strict_date_optional_time||epoch_millis&quot;</span>
               },
               <span class="hljs-string">&quot;name&quot;</span>: {
                  <span class="hljs-string">&quot;type&quot;</span>: <span class="hljs-string">&quot;string&quot;</span>
               },
               <span class="hljs-string">&quot;tweet&quot;</span>: {
                  <span class="hljs-string">&quot;type&quot;</span>: <span class="hljs-string">&quot;string&quot;</span>
               },
               <span class="hljs-string">&quot;user_id&quot;</span>: {
                  <span class="hljs-string">&quot;type&quot;</span>: <span class="hljs-string">&quot;long&quot;</span>
               }
            }
         }
      }
   }
}
</code></pre>
<p>&#x57FA;&#x4E8E;&#x5BF9;&#x5B57;&#x6BB5;&#x7C7B;&#x578B;&#x7684;&#x731C;&#x6D4B;&#xFF0C; Elasticsearch &#x52A8;&#x6001;&#x4E3A;&#x6211;&#x4EEC;&#x4EA7;&#x751F;&#x4E86;&#x4E00;&#x4E2A;&#x6620;&#x5C04;&#x3002;&#x8FD9;&#x4E2A;&#x54CD;&#x5E94;&#x544A;&#x8BC9;&#x6211;&#x4EEC; <code>date</code> &#x5B57;&#x6BB5;&#x88AB;&#x8BA4;&#x4E3A;&#x662F; <code>date</code> &#x7C7B;&#x578B;&#x7684;&#x3002;&#x7531;&#x4E8E; <code>_all</code> &#x662F;&#x9ED8;&#x8BA4;&#x5B57;&#x6BB5;&#xFF0C;&#x6240;&#x4EE5;&#x6CA1;&#x6709;&#x63D0;&#x53CA;&#x5B83;&#x3002;&#x4F46;&#x662F;&#x6211;&#x4EEC;&#x77E5;&#x9053; <code>_all</code> &#x5B57;&#x6BB5;&#x662F; <code>string</code> &#x7C7B;&#x578B;&#x7684;&#x3002;</p>
<p>&#x6240;&#x4EE5; <code>date</code> &#x5B57;&#x6BB5;&#x548C; <code>string</code> &#x5B57;&#x6BB5; &#x7D22;&#x5F15;&#x65B9;&#x5F0F;&#x4E0D;&#x540C;&#xFF0C;&#x56E0;&#x6B64;&#x641C;&#x7D22;&#x7ED3;&#x679C;&#x4E5F;&#x4E0D;&#x4E00;&#x6837;&#x3002;&#x8FD9;&#x5B8C;&#x5168;&#x4E0D;&#x4EE4;&#x4EBA;&#x5403;&#x60CA;&#x3002;&#x4F60;&#x53EF;&#x80FD;&#x4F1A;&#x8BA4;&#x4E3A; &#x6838;&#x5FC3;&#x6570;&#x636E;&#x7C7B;&#x578B; strings&#x3001;numbers&#x3001;Booleans &#x548C; dates &#x7684;&#x7D22;&#x5F15;&#x65B9;&#x5F0F;&#x6709;&#x7A0D;&#x8BB8;&#x4E0D;&#x540C;&#x3002;&#x6CA1;&#x9519;&#xFF0C;&#x4ED6;&#x4EEC;&#x786E;&#x5B9E;&#x7A0D;&#x6709;&#x4E0D;&#x540C;&#x3002;</p>
<p>&#x4F46;&#x662F;&#xFF0C;&#x5230;&#x76EE;&#x524D;&#x4E3A;&#x6B62;&#xFF0C;&#x6700;&#x5927;&#x7684;&#x5DEE;&#x5F02;&#x5728;&#x4E8E; &#x4EE3;&#x8868; <em>&#x7CBE;&#x786E;&#x503C;</em> &#xFF08;&#x5B83;&#x5305;&#x62EC; <code>string</code> &#x5B57;&#x6BB5;&#xFF09;&#x7684;&#x5B57;&#x6BB5;&#x548C;&#x4EE3;&#x8868; <em>&#x5168;&#x6587;</em> &#x7684;&#x5B57;&#x6BB5;&#x3002;&#x8FD9;&#x4E2A;&#x533A;&#x522B;&#x975E;&#x5E38;&#x91CD;&#x8981;&#x2014;&#x2014;&#x5B83;&#x5C06;&#x641C;&#x7D22;&#x5F15;&#x64CE;&#x548C;&#x6240;&#x6709;&#x5176;&#x4ED6;&#x6570;&#x636E;&#x5E93;&#x533A;&#x522B;&#x5F00;&#x6765;&#x3002;</p>
<h3 id="&#x7CBE;&#x786E;&#x503C;VS&#x5168;&#x6587;"><a name="&#x7CBE;&#x786E;&#x503C;VS&#x5168;&#x6587;" class="anchor-navigation-ex-anchor" href="#&#x7CBE;&#x786E;&#x503C;VS&#x5168;&#x6587;"><i class="fa fa-link" aria-hidden="true"></i></a>&#x7CBE;&#x786E;&#x503C; VS &#x5168;&#x6587;  </h3>
<p>Elasticsearch &#x4E2D;&#x7684;&#x6570;&#x636E;&#x53EF;&#x4EE5;&#x6982;&#x62EC;&#x7684;&#x5206;&#x4E3A;&#x4E24;&#x7C7B;&#xFF1A;&#x7CBE;&#x786E;&#x503C;&#x548C;&#x5168;&#x6587;&#x3002;</p>
<p><em>&#x7CBE;&#x786E;&#x503C;</em> &#x5982;&#x5B83;&#x4EEC;&#x542C;&#x8D77;&#x6765;&#x90A3;&#x6837;&#x7CBE;&#x786E;&#x3002;&#x4F8B;&#x5982;&#x65E5;&#x671F;&#x6216;&#x8005;&#x7528;&#x6237; ID&#xFF0C;&#x4F46;&#x5B57;&#x7B26;&#x4E32;&#x4E5F;&#x53EF;&#x4EE5;&#x8868;&#x793A;&#x7CBE;&#x786E;&#x503C;&#xFF0C;&#x4F8B;&#x5982;&#x7528;&#x6237;&#x540D;&#x6216;&#x90AE;&#x7BB1;&#x5730;&#x5740;&#x3002;&#x5BF9;&#x4E8E;&#x7CBE;&#x786E;&#x503C;&#x6765;&#x8BB2;&#xFF0C;<code>Foo</code> &#x548C; <code>foo</code> &#x662F;&#x4E0D;&#x540C;&#x7684;&#xFF0C;<code>2014</code> &#x548C; <code>2014-09-15</code> &#x4E5F;&#x662F;&#x4E0D;&#x540C;&#x7684;&#x3002;</p>
<p>&#x53E6;&#x4E00;&#x65B9;&#x9762;&#xFF0C;<em>&#x5168;&#x6587;</em> &#x662F;&#x6307;&#x6587;&#x672C;&#x6570;&#x636E;&#xFF08;&#x901A;&#x5E38;&#x4EE5;&#x4EBA;&#x7C7B;&#x5BB9;&#x6613;&#x8BC6;&#x522B;&#x7684;&#x8BED;&#x8A00;&#x4E66;&#x5199;&#xFF09;&#xFF0C;&#x4F8B;&#x5982;&#x4E00;&#x4E2A;&#x63A8;&#x6587;&#x7684;&#x5185;&#x5BB9;&#x6216;&#x4E00;&#x5C01;&#x90AE;&#x4EF6;&#x7684;&#x5185;&#x5BB9;&#x3002;</p>
<blockquote>
<p> <img src="assets/note.png" alt="&#x6CE8;&#x610F;">  &#x5168;&#x6587;&#x901A;&#x5E38;&#x662F;&#x6307;&#x975E;&#x7ED3;&#x6784;&#x5316;&#x7684;&#x6570;&#x636E;&#xFF0C;&#x4F46;&#x8FD9;&#x91CC;&#x6709;&#x4E00;&#x4E2A;&#x8BEF;&#x89E3;&#xFF1A;&#x81EA;&#x7136;&#x8BED;&#x8A00;&#x662F;&#x9AD8;&#x5EA6;&#x7ED3;&#x6784;&#x5316;&#x7684;&#x3002;&#x95EE;&#x9898;&#x5728;&#x4E8E;&#x81EA;&#x7136;&#x8BED;&#x8A00;&#x7684;&#x89C4;&#x5219;&#x662F;&#x590D;&#x6742;&#x7684;&#xFF0C;&#x5BFC;&#x81F4;&#x8BA1;&#x7B97;&#x673A;&#x96BE;&#x4EE5;&#x6B63;&#x786E;&#x89E3;&#x6790;&#x3002;&#x4F8B;&#x5982;&#xFF0C;&#x8003;&#x8651;&#x8FD9;&#x6761;&#x8BED;&#x53E5;&#xFF1A;</p>
</blockquote>
<pre><code>May is fun but June bores me.
</code></pre><p>&#x5B83;&#x6307;&#x7684;&#x662F;&#x6708;&#x4EFD;&#x8FD8;&#x662F;&#x4EBA;&#xFF1F;</p>
<p>&#x7CBE;&#x786E;&#x503C;&#x5F88;&#x5BB9;&#x6613;&#x67E5;&#x8BE2;&#x3002;&#x7ED3;&#x679C;&#x662F;&#x4E8C;&#x8FDB;&#x5236;&#x7684;&#xFF1A;&#x8981;&#x4E48;&#x5339;&#x914D;&#x67E5;&#x8BE2;&#xFF0C;&#x8981;&#x4E48;&#x4E0D;&#x5339;&#x914D;&#x3002;&#x8FD9;&#x79CD;&#x67E5;&#x8BE2;&#x5F88;&#x5BB9;&#x6613;&#x7528; SQL &#x8868;&#x793A;&#xFF1A;</p>
<pre><code class="lang-js">WHERE name    = <span class="hljs-string">&quot;John Smith&quot;</span>
  AND user_id = <span class="hljs-number">2</span>
  AND date    &gt; <span class="hljs-string">&quot;2014-09-15&quot;</span>
</code></pre>
<p>&#x67E5;&#x8BE2;&#x5168;&#x6587;&#x6570;&#x636E;&#x8981;&#x5FAE;&#x5999;&#x7684;&#x591A;&#x3002;&#x6211;&#x4EEC;&#x95EE;&#x7684;&#x4E0D;&#x53EA;&#x662F;&#x201C;&#x8FD9;&#x4E2A;&#x6587;&#x6863;&#x5339;&#x914D;&#x67E5;&#x8BE2;&#x5417;&#x201D;&#xFF0C;&#x800C;&#x662F;&#x201C;&#x8BE5;&#x6587;&#x6863;&#x5339;&#x914D;&#x67E5;&#x8BE2;&#x7684;&#x7A0B;&#x5EA6;&#x6709;&#x591A;&#x5927;&#xFF1F;&#x201D;&#x6362;&#x53E5;&#x8BDD;&#x8BF4;&#xFF0C;&#x8BE5;&#x6587;&#x6863;&#x4E0E;&#x7ED9;&#x5B9A;&#x67E5;&#x8BE2;&#x7684;&#x76F8;&#x5173;&#x6027;&#x5982;&#x4F55;&#xFF1F;</p>
<p>&#x6211;&#x4EEC;&#x5F88;&#x5C11;&#x5BF9;&#x5168;&#x6587;&#x7C7B;&#x578B;&#x7684;&#x57DF;&#x505A;&#x7CBE;&#x786E;&#x5339;&#x914D;&#x3002;&#x76F8;&#x53CD;&#xFF0C;&#x6211;&#x4EEC;&#x5E0C;&#x671B;&#x5728;&#x6587;&#x672C;&#x7C7B;&#x578B;&#x7684;&#x57DF;&#x4E2D;&#x641C;&#x7D22;&#x3002;&#x4E0D;&#x4EC5;&#x5982;&#x6B64;&#xFF0C;&#x6211;&#x4EEC;&#x8FD8;&#x5E0C;&#x671B;&#x641C;&#x7D22;&#x80FD;&#x591F;&#x7406;&#x89E3;&#x6211;&#x4EEC;&#x7684; <em>&#x610F;&#x56FE;</em> &#xFF1A;</p>
<ul>
<li>&#x641C;&#x7D22; <code>UK</code> &#xFF0C;&#x4F1A;&#x8FD4;&#x56DE;&#x5305;&#x542B; <code>United Kindom</code> &#x7684;&#x6587;&#x6863;&#x3002;</li>
<li>&#x641C;&#x7D22; <code>jump</code> &#xFF0C;&#x4F1A;&#x5339;&#x914D; <code>jumped</code> &#xFF0C; <code>jumps</code> &#xFF0C; <code>jumping</code> &#xFF0C;&#x751A;&#x81F3;&#x662F; <code>leap</code> &#x3002;</li>
<li>&#x641C;&#x7D22; <code>johnny walker</code> &#x4F1A;&#x5339;&#x914D; <code>Johnnie Walker</code> &#xFF0C; <code>johnnie depp</code> &#x5E94;&#x8BE5;&#x5339;&#x914D; <code>Johnny Depp</code> &#x3002;</li>
<li><code>fox news hunting</code> &#x5E94;&#x8BE5;&#x8FD4;&#x56DE;&#x798F;&#x514B;&#x65AF;&#x65B0;&#x95FB;&#xFF08; Foxs News &#xFF09;&#x4E2D;&#x5173;&#x4E8E;&#x72E9;&#x730E;&#x7684;&#x6545;&#x4E8B;&#xFF0C;&#x540C;&#x65F6;&#xFF0C; <code>fox hunting news</code> &#x5E94;&#x8BE5;&#x8FD4;&#x56DE;&#x5173;&#x4E8E;&#x730E;&#x72D0;&#x7684;&#x6545;&#x4E8B;&#x3002;</li>
</ul>
<p>&#x4E3A;&#x4E86;&#x4FC3;&#x8FDB;&#x8FD9;&#x7C7B;&#x5728;&#x5168;&#x6587;&#x57DF;&#x4E2D;&#x7684;&#x67E5;&#x8BE2;&#xFF0C;Elasticsearch &#x9996;&#x5148; <em>&#x5206;&#x6790;</em> &#x6587;&#x6863;&#xFF0C;&#x4E4B;&#x540E;&#x6839;&#x636E;&#x7ED3;&#x679C;&#x521B;&#x5EFA; <em>&#x5012;&#x6392;&#x7D22;&#x5F15;</em> &#x3002;&#x5728;&#x63A5;&#x4E0B;&#x6765;&#x7684;&#x4E24;&#x8282;&#xFF0C;&#x6211;&#x4EEC;&#x4F1A;&#x8BA8;&#x8BBA;&#x5012;&#x6392;&#x7D22;&#x5F15;&#x548C;&#x5206;&#x6790;&#x8FC7;&#x7A0B;&#x3002;</p>
<h3 id="&#x5012;&#x6392;&#x7D22;&#x5F15;"><a name="&#x5012;&#x6392;&#x7D22;&#x5F15;" class="anchor-navigation-ex-anchor" href="#&#x5012;&#x6392;&#x7D22;&#x5F15;"><i class="fa fa-link" aria-hidden="true"></i></a>&#x5012;&#x6392;&#x7D22;&#x5F15;</h3>
<p>Elasticsearch &#x4F7F;&#x7528;&#x4E00;&#x79CD;&#x79F0;&#x4E3A; <em>&#x5012;&#x6392;&#x7D22;&#x5F15;</em> &#x7684;&#x7ED3;&#x6784;&#xFF0C;&#x5B83;&#x9002;&#x7528;&#x4E8E;&#x5FEB;&#x901F;&#x7684;&#x5168;&#x6587;&#x641C;&#x7D22;&#x3002;&#x4E00;&#x4E2A;&#x5012;&#x6392;&#x7D22;&#x5F15;&#x7531;&#x6587;&#x6863;&#x4E2D;&#x6240;&#x6709;&#x4E0D;&#x91CD;&#x590D;&#x8BCD;&#x7684;&#x5217;&#x8868;&#x6784;&#x6210;&#xFF0C;&#x5BF9;&#x4E8E;&#x5176;&#x4E2D;&#x6BCF;&#x4E2A;&#x8BCD;&#xFF0C;&#x6709;&#x4E00;&#x4E2A;&#x5305;&#x542B;&#x5B83;&#x7684;&#x6587;&#x6863;&#x5217;&#x8868;&#x3002;</p>
<p>&#x4F8B;&#x5982;&#xFF0C;&#x5047;&#x8BBE;&#x6211;&#x4EEC;&#x6709;&#x4E24;&#x4E2A;&#x6587;&#x6863;&#xFF0C;&#x6BCF;&#x4E2A;&#x6587;&#x6863;&#x7684; <code>content</code> &#x57DF;&#x5305;&#x542B;&#x5982;&#x4E0B;&#x5185;&#x5BB9;&#xFF1A;</p>
<ol>
<li>The quick brown fox jumped over the lazy dog</li>
<li>Quick brown foxes leap over lazy dogs in summer</li>
</ol>
<p>&#x4E3A;&#x4E86;&#x521B;&#x5EFA;&#x5012;&#x6392;&#x7D22;&#x5F15;&#xFF0C;&#x6211;&#x4EEC;&#x9996;&#x5148;&#x5C06;&#x6BCF;&#x4E2A;&#x6587;&#x6863;&#x7684; <code>content</code> &#x57DF;&#x62C6;&#x5206;&#x6210;&#x5355;&#x72EC;&#x7684; &#x8BCD;&#xFF08;&#x6211;&#x4EEC;&#x79F0;&#x5B83;&#x4E3A; <code>&#x8BCD;&#x6761;</code> &#x6216; <code>tokens</code>&#xFF09;&#xFF0C;&#x521B;&#x5EFA;&#x4E00;&#x4E2A;&#x5305;&#x542B;&#x6240;&#x6709;&#x4E0D;&#x91CD;&#x590D;&#x8BCD;&#x6761;&#x7684;&#x6392;&#x5E8F;&#x5217;&#x8868;&#xFF0C;&#x7136;&#x540E;&#x5217;&#x51FA;&#x6BCF;&#x4E2A;&#x8BCD;&#x6761;&#x51FA;&#x73B0;&#x5728;&#x54EA;&#x4E2A;&#x6587;&#x6863;&#x3002;&#x7ED3;&#x679C;&#x5982;&#x4E0B;&#x6240;&#x793A;&#xFF1A;</p>
<pre><code>Term      Doc_1  Doc_2
-------------------------
Quick   |       |  X
The     |   X   |
brown   |   X   |  X
dog     |   X   |
dogs    |       |  X
fox     |   X   |
foxes   |       |  X
in      |       |  X
jumped  |   X   |
lazy    |   X   |  X
leap    |       |  X
over    |   X   |  X
quick   |   X   |
summer  |       |  X
the     |   X   |
------------------------
</code></pre><p>&#x73B0;&#x5728;&#xFF0C;&#x5982;&#x679C;&#x6211;&#x4EEC;&#x60F3;&#x641C;&#x7D22; <code>quick brown</code> &#xFF0C;&#x6211;&#x4EEC;&#x53EA;&#x9700;&#x8981;&#x67E5;&#x627E;&#x5305;&#x542B;&#x6BCF;&#x4E2A;&#x8BCD;&#x6761;&#x7684;&#x6587;&#x6863;&#xFF1A;</p>
<pre><code>Term      Doc_1  Doc_2
-------------------------
brown   |   X   |  X
quick   |   X   |
------------------------
Total   |   2   |  1
</code></pre><p>&#x4E24;&#x4E2A;&#x6587;&#x6863;&#x90FD;&#x5339;&#x914D;&#xFF0C;&#x4F46;&#x662F;&#x7B2C;&#x4E00;&#x4E2A;&#x6587;&#x6863;&#x6BD4;&#x7B2C;&#x4E8C;&#x4E2A;&#x5339;&#x914D;&#x5EA6;&#x66F4;&#x9AD8;&#x3002;&#x5982;&#x679C;&#x6211;&#x4EEC;&#x4F7F;&#x7528;&#x4EC5;&#x8BA1;&#x7B97;&#x5339;&#x914D;&#x8BCD;&#x6761;&#x6570;&#x91CF;&#x7684;&#x7B80;&#x5355; <em>&#x76F8;&#x4F3C;&#x6027;&#x7B97;&#x6CD5;</em> &#xFF0C;&#x90A3;&#x4E48;&#xFF0C;&#x6211;&#x4EEC;&#x53EF;&#x4EE5;&#x8BF4;&#xFF0C;&#x5BF9;&#x4E8E;&#x6211;&#x4EEC;&#x67E5;&#x8BE2;&#x7684;&#x76F8;&#x5173;&#x6027;&#x6765;&#x8BB2;&#xFF0C;&#x7B2C;&#x4E00;&#x4E2A;&#x6587;&#x6863;&#x6BD4;&#x7B2C;&#x4E8C;&#x4E2A;&#x6587;&#x6863;&#x66F4;&#x4F73;&#x3002;</p>
<p>&#x4F46;&#x662F;&#xFF0C;&#x6211;&#x4EEC;&#x76EE;&#x524D;&#x7684;&#x5012;&#x6392;&#x7D22;&#x5F15;&#x6709;&#x4E00;&#x4E9B;&#x95EE;&#x9898;&#xFF1A;</p>
<ul>
<li><code>Quick</code> &#x548C; <code>quick</code> &#x4EE5;&#x72EC;&#x7ACB;&#x7684;&#x8BCD;&#x6761;&#x51FA;&#x73B0;&#xFF0C;&#x7136;&#x800C;&#x7528;&#x6237;&#x53EF;&#x80FD;&#x8BA4;&#x4E3A;&#x5B83;&#x4EEC;&#x662F;&#x76F8;&#x540C;&#x7684;&#x8BCD;&#x3002;</li>
<li><code>fox</code> &#x548C; <code>foxes</code> &#x975E;&#x5E38;&#x76F8;&#x4F3C;, &#x5C31;&#x50CF; <code>dog</code> &#x548C; <code>dogs</code> &#xFF1B;&#x4ED6;&#x4EEC;&#x6709;&#x76F8;&#x540C;&#x7684;&#x8BCD;&#x6839;&#x3002;</li>
<li><code>jumped</code> &#x548C; <code>leap</code>, &#x5C3D;&#x7BA1;&#x6CA1;&#x6709;&#x76F8;&#x540C;&#x7684;&#x8BCD;&#x6839;&#xFF0C;&#x4F46;&#x4ED6;&#x4EEC;&#x7684;&#x610F;&#x601D;&#x5F88;&#x76F8;&#x8FD1;&#x3002;&#x4ED6;&#x4EEC;&#x662F;&#x540C;&#x4E49;&#x8BCD;&#x3002;</li>
</ul>
<p>&#x4F7F;&#x7528;&#x524D;&#x9762;&#x7684;&#x7D22;&#x5F15;&#x641C;&#x7D22; <code>+Quick +fox</code> &#x4E0D;&#x4F1A;&#x5F97;&#x5230;&#x4EFB;&#x4F55;&#x5339;&#x914D;&#x6587;&#x6863;&#x3002;&#xFF08;&#x8BB0;&#x4F4F;&#xFF0C;<code>+</code> &#x524D;&#x7F00;&#x8868;&#x660E;&#x8FD9;&#x4E2A;&#x8BCD;&#x5FC5;&#x987B;&#x5B58;&#x5728;&#x3002;&#xFF09;&#x53EA;&#x6709;&#x540C;&#x65F6;&#x51FA;&#x73B0; <code>Quick</code> &#x548C; <code>fox</code> &#x7684;&#x6587;&#x6863;&#x624D;&#x6EE1;&#x8DB3;&#x8FD9;&#x4E2A;&#x67E5;&#x8BE2;&#x6761;&#x4EF6;&#xFF0C;&#x4F46;&#x662F;&#x7B2C;&#x4E00;&#x4E2A;&#x6587;&#x6863;&#x5305;&#x542B; <code>quick fox</code> &#xFF0C;&#x7B2C;&#x4E8C;&#x4E2A;&#x6587;&#x6863;&#x5305;&#x542B; <code>Quick foxes</code> &#x3002;</p>
<p>&#x6211;&#x4EEC;&#x7684;&#x7528;&#x6237;&#x53EF;&#x4EE5;&#x5408;&#x7406;&#x7684;&#x671F;&#x671B;&#x4E24;&#x4E2A;&#x6587;&#x6863;&#x4E0E;&#x67E5;&#x8BE2;&#x5339;&#x914D;&#x3002;&#x6211;&#x4EEC;&#x53EF;&#x4EE5;&#x505A;&#x7684;&#x66F4;&#x597D;&#x3002;</p>
<p>&#x5982;&#x679C;&#x6211;&#x4EEC;&#x5C06;&#x8BCD;&#x6761;&#x89C4;&#x8303;&#x4E3A;&#x6807;&#x51C6;&#x6A21;&#x5F0F;&#xFF0C;&#x90A3;&#x4E48;&#x6211;&#x4EEC;&#x53EF;&#x4EE5;&#x627E;&#x5230;&#x4E0E;&#x7528;&#x6237;&#x641C;&#x7D22;&#x7684;&#x8BCD;&#x6761;&#x4E0D;&#x5B8C;&#x5168;&#x4E00;&#x81F4;&#xFF0C;&#x4F46;&#x5177;&#x6709;&#x8DB3;&#x591F;&#x76F8;&#x5173;&#x6027;&#x7684;&#x6587;&#x6863;&#x3002;&#x4F8B;&#x5982;&#xFF1A;</p>
<ul>
<li><code>Quick</code> &#x53EF;&#x4EE5;&#x5C0F;&#x5199;&#x5316;&#x4E3A; <code>quick</code> &#x3002;</li>
<li><code>foxes</code> &#x53EF;&#x4EE5; <em>&#x8BCD;&#x5E72;&#x63D0;&#x53D6;</em> --&#x53D8;&#x4E3A;&#x8BCD;&#x6839;&#x7684;&#x683C;&#x5F0F;-- &#x4E3A; <code>fox</code> &#x3002;&#x7C7B;&#x4F3C;&#x7684;&#xFF0C; <code>dogs</code> &#x53EF;&#x4EE5;&#x4E3A;&#x63D0;&#x53D6;&#x4E3A; <code>dog</code> &#x3002;</li>
<li><code>jumped</code> &#x548C; <code>leap</code> &#x662F;&#x540C;&#x4E49;&#x8BCD;&#xFF0C;&#x53EF;&#x4EE5;&#x7D22;&#x5F15;&#x4E3A;&#x76F8;&#x540C;&#x7684;&#x5355;&#x8BCD; <code>jump</code> &#x3002;</li>
</ul>
<p>&#x73B0;&#x5728;&#x7D22;&#x5F15;&#x770B;&#x4E0A;&#x53BB;&#x50CF;&#x8FD9;&#x6837;&#xFF1A;</p>
<pre><code>Term      Doc_1  Doc_2
-------------------------
brown   |   X   |  X
dog     |   X   |  X
fox     |   X   |  X
in      |       |  X
jump    |   X   |  X
lazy    |   X   |  X
over    |   X   |  X
quick   |   X   |  X
summer  |       |  X
the     |   X   |  X
------------------------
</code></pre><p>&#x8FD9;&#x8FD8;&#x8FDC;&#x8FDC;&#x4E0D;&#x591F;&#x3002;&#x6211;&#x4EEC;&#x641C;&#x7D22; <code>+Quick +fox</code> <em>&#x4ECD;&#x7136;</em> &#x4F1A;&#x5931;&#x8D25;&#xFF0C;&#x56E0;&#x4E3A;&#x5728;&#x6211;&#x4EEC;&#x7684;&#x7D22;&#x5F15;&#x4E2D;&#xFF0C;&#x5DF2;&#x7ECF;&#x6CA1;&#x6709; <code>Quick</code> &#x4E86;&#x3002;&#x4F46;&#x662F;&#xFF0C;&#x5982;&#x679C;&#x6211;&#x4EEC;&#x5BF9;&#x641C;&#x7D22;&#x7684;&#x5B57;&#x7B26;&#x4E32;&#x4F7F;&#x7528;&#x4E0E; <code>content</code> &#x57DF;&#x76F8;&#x540C;&#x7684;&#x6807;&#x51C6;&#x5316;&#x89C4;&#x5219;&#xFF0C;&#x4F1A;&#x53D8;&#x6210;&#x67E5;&#x8BE2; <code>+quick +fox</code> &#xFF0C;&#x8FD9;&#x6837;&#x4E24;&#x4E2A;&#x6587;&#x6863;&#x90FD;&#x4F1A;&#x5339;&#x914D;&#xFF01;</p>
<blockquote>
<p> <img src="assets/note.png" alt="&#x6CE8;&#x610F;">  &#x8FD9;&#x975E;&#x5E38;&#x91CD;&#x8981;&#x3002;&#x4F60;&#x53EA;&#x80FD;&#x641C;&#x7D22;&#x5728;&#x7D22;&#x5F15;&#x4E2D;&#x51FA;&#x73B0;&#x7684;&#x8BCD;&#x6761;&#xFF0C;&#x6240;&#x4EE5;&#x7D22;&#x5F15;&#x6587;&#x672C;&#x548C;&#x67E5;&#x8BE2;&#x5B57;&#x7B26;&#x4E32;&#x5FC5;&#x987B;&#x6807;&#x51C6;&#x5316;&#x4E3A;&#x76F8;&#x540C;&#x7684;&#x683C;&#x5F0F;&#x3002;</p>
</blockquote>
<p>&#x5206;&#x8BCD;&#x548C;&#x6807;&#x51C6;&#x5316;&#x7684;&#x8FC7;&#x7A0B;&#x79F0;&#x4E3A; <em>&#x5206;&#x6790;</em> &#xFF0C; &#x6211;&#x4EEC;&#x4F1A;&#x5728;&#x4E0B;&#x4E2A;&#x7AE0;&#x8282;&#x8BA8;&#x8BBA;&#x3002;</p>
<h3 id="&#x5206;&#x6790;&#x4E0E;&#x5206;&#x6790;&#x5668;"><a name="&#x5206;&#x6790;&#x4E0E;&#x5206;&#x6790;&#x5668;" class="anchor-navigation-ex-anchor" href="#&#x5206;&#x6790;&#x4E0E;&#x5206;&#x6790;&#x5668;"><i class="fa fa-link" aria-hidden="true"></i></a>&#x5206;&#x6790;&#x4E0E;&#x5206;&#x6790;&#x5668;</h3>
<p><em>&#x5206;&#x6790;</em> &#x5305;&#x542B;&#x4E0B;&#x9762;&#x7684;&#x8FC7;&#x7A0B;&#xFF1A;</p>
<ul>
<li>&#x9996;&#x5148;&#xFF0C;&#x5C06;&#x4E00;&#x5757;&#x6587;&#x672C;&#x5206;&#x6210;&#x9002;&#x5408;&#x4E8E;&#x5012;&#x6392;&#x7D22;&#x5F15;&#x7684;&#x72EC;&#x7ACB;&#x7684; <em>&#x8BCD;&#x6761;</em> &#xFF0C;</li>
<li>&#x4E4B;&#x540E;&#xFF0C;&#x5C06;&#x8FD9;&#x4E9B;&#x8BCD;&#x6761;&#x7EDF;&#x4E00;&#x5316;&#x4E3A;&#x6807;&#x51C6;&#x683C;&#x5F0F;&#x4EE5;&#x63D0;&#x9AD8;&#x5B83;&#x4EEC;&#x7684;&#x201C;&#x53EF;&#x641C;&#x7D22;&#x6027;&#x201D;&#xFF0C;&#x6216;&#x8005; <em>recall</em></li>
</ul>
<p>&#x5206;&#x6790;&#x5668;&#x6267;&#x884C;&#x4E0A;&#x9762;&#x7684;&#x5DE5;&#x4F5C;&#x3002; <em>&#x5206;&#x6790;&#x5668;</em> &#x5B9E;&#x9645;&#x4E0A;&#x662F;&#x5C06;&#x4E09;&#x4E2A;&#x529F;&#x80FD;&#x5C01;&#x88C5;&#x5230;&#x4E86;&#x4E00;&#x4E2A;&#x5305;&#x91CC;&#xFF1A;</p>
<ul>
<li><p>&#x5B57;&#x7B26;&#x8FC7;&#x6EE4;&#x5668;</p>
<p>&#x9996;&#x5148;&#xFF0C;&#x5B57;&#x7B26;&#x4E32;&#x6309;&#x987A;&#x5E8F;&#x901A;&#x8FC7;&#x6BCF;&#x4E2A; <em>&#x5B57;&#x7B26;&#x8FC7;&#x6EE4;&#x5668;</em> &#x3002;&#x4ED6;&#x4EEC;&#x7684;&#x4EFB;&#x52A1;&#x662F;&#x5728;&#x5206;&#x8BCD;&#x524D;&#x6574;&#x7406;&#x5B57;&#x7B26;&#x4E32;&#x3002;&#x4E00;&#x4E2A;&#x5B57;&#x7B26;&#x8FC7;&#x6EE4;&#x5668;&#x53EF;&#x4EE5;&#x7528;&#x6765;&#x53BB;&#x6389;HTML&#xFF0C;&#x6216;&#x8005;&#x5C06; <code>&amp;</code> &#x8F6C;&#x5316;&#x6210; <code>and</code>&#x3002;</p>
</li>
<li><p>&#x5206;&#x8BCD;&#x5668;</p>
<p>&#x5176;&#x6B21;&#xFF0C;&#x5B57;&#x7B26;&#x4E32;&#x88AB; <em>&#x5206;&#x8BCD;&#x5668;</em> &#x5206;&#x4E3A;&#x5355;&#x4E2A;&#x7684;&#x8BCD;&#x6761;&#x3002;&#x4E00;&#x4E2A;&#x7B80;&#x5355;&#x7684;&#x5206;&#x8BCD;&#x5668;&#x9047;&#x5230;&#x7A7A;&#x683C;&#x548C;&#x6807;&#x70B9;&#x7684;&#x65F6;&#x5019;&#xFF0C;&#x53EF;&#x80FD;&#x4F1A;&#x5C06;&#x6587;&#x672C;&#x62C6;&#x5206;&#x6210;&#x8BCD;&#x6761;&#x3002;</p>
</li>
<li><p>Token &#x8FC7;&#x6EE4;&#x5668;</p>
<p>&#x6700;&#x540E;&#xFF0C;&#x8BCD;&#x6761;&#x6309;&#x987A;&#x5E8F;&#x901A;&#x8FC7;&#x6BCF;&#x4E2A; <em>token &#x8FC7;&#x6EE4;&#x5668;</em> &#x3002;&#x8FD9;&#x4E2A;&#x8FC7;&#x7A0B;&#x53EF;&#x80FD;&#x4F1A;&#x6539;&#x53D8;&#x8BCD;&#x6761;&#xFF08;&#x4F8B;&#x5982;&#xFF0C;&#x5C0F;&#x5199;&#x5316; <code>Quick</code> &#xFF09;&#xFF0C;&#x5220;&#x9664;&#x8BCD;&#x6761;&#xFF08;&#x4F8B;&#x5982;&#xFF0C; &#x50CF; <code>a</code>&#xFF0C; <code>and</code>&#xFF0C; <code>the</code> &#x7B49;&#x65E0;&#x7528;&#x8BCD;&#xFF09;&#xFF0C;&#x6216;&#x8005;&#x589E;&#x52A0;&#x8BCD;&#x6761;&#xFF08;&#x4F8B;&#x5982;&#xFF0C;&#x50CF; <code>jump</code> &#x548C; <code>leap</code> &#x8FD9;&#x79CD;&#x540C;&#x4E49;&#x8BCD;&#xFF09;&#x3002;</p>
</li>
</ul>
<p>Elasticsearch&#x63D0;&#x4F9B;&#x4E86;&#x5F00;&#x7BB1;&#x5373;&#x7528;&#x7684;&#x5B57;&#x7B26;&#x8FC7;&#x6EE4;&#x5668;&#x3001;&#x5206;&#x8BCD;&#x5668;&#x548C;token &#x8FC7;&#x6EE4;&#x5668;&#x3002; &#x8FD9;&#x4E9B;&#x53EF;&#x4EE5;&#x7EC4;&#x5408;&#x8D77;&#x6765;&#x5F62;&#x6210;&#x81EA;&#x5B9A;&#x4E49;&#x7684;&#x5206;&#x6790;&#x5668;&#x4EE5;&#x7528;&#x4E8E;&#x4E0D;&#x540C;&#x7684;&#x76EE;&#x7684;&#x3002;&#x6211;&#x4EEC;&#x4F1A;&#x5728; <a href="https://www.elastic.co/guide/cn/elasticsearch/guide/current/custom-analyzers.html" target="_blank">&#x81EA;&#x5B9A;&#x4E49;&#x5206;&#x6790;&#x5668;</a> &#x7AE0;&#x8282;&#x8BE6;&#x7EC6;&#x8BA8;&#x8BBA;&#x3002;</p>
<p><strong>&#x5185;&#x7F6E;&#x5206;&#x6790;&#x5668;</strong></p>
<p>&#x4F46;&#x662F;&#xFF0C; Elasticsearch&#x8FD8;&#x9644;&#x5E26;&#x4E86;&#x53EF;&#x4EE5;&#x76F4;&#x63A5;&#x4F7F;&#x7528;&#x7684;&#x9884;&#x5305;&#x88C5;&#x7684;&#x5206;&#x6790;&#x5668;&#x3002; &#x63A5;&#x4E0B;&#x6765;&#x6211;&#x4EEC;&#x4F1A;&#x5217;&#x51FA;&#x6700;&#x91CD;&#x8981;&#x7684;&#x5206;&#x6790;&#x5668;&#x3002;&#x4E3A;&#x4E86;&#x8BC1;&#x660E;&#x5B83;&#x4EEC;&#x7684;&#x5DEE;&#x5F02;&#xFF0C;&#x6211;&#x4EEC;&#x770B;&#x770B;&#x6BCF;&#x4E2A;&#x5206;&#x6790;&#x5668;&#x4F1A;&#x4ECE;&#x4E0B;&#x9762;&#x7684;&#x5B57;&#x7B26;&#x4E32;&#x5F97;&#x5230;&#x54EA;&#x4E9B;&#x8BCD;&#x6761;&#xFF1A;</p>
<pre><code>&quot;Set the shape to semi-transparent by calling set_trans(5)&quot;
</code></pre><ul>
<li><p>&#x6807;&#x51C6;&#x5206;&#x6790;&#x5668;</p>
<p>&#x6807;&#x51C6;&#x5206;&#x6790;&#x5668;&#x662F;Elasticsearch&#x9ED8;&#x8BA4;&#x4F7F;&#x7528;&#x7684;&#x5206;&#x6790;&#x5668;&#x3002;&#x5B83;&#x662F;&#x5206;&#x6790;&#x5404;&#x79CD;&#x8BED;&#x8A00;&#x6587;&#x672C;&#x6700;&#x5E38;&#x7528;&#x7684;&#x9009;&#x62E9;&#x3002;&#x5B83;&#x6839;&#x636E; <a href="http://www.unicode.org/reports/tr29/" target="_blank">Unicode &#x8054;&#x76DF;</a> &#x5B9A;&#x4E49;&#x7684; <em>&#x5355;&#x8BCD;&#x8FB9;&#x754C;</em> &#x5212;&#x5206;&#x6587;&#x672C;&#x3002;&#x5220;&#x9664;&#x7EDD;&#x5927;&#x90E8;&#x5206;&#x6807;&#x70B9;&#x3002;&#x6700;&#x540E;&#xFF0C;&#x5C06;&#x8BCD;&#x6761;&#x5C0F;&#x5199;&#x3002;&#x5B83;&#x4F1A;&#x4EA7;&#x751F;<code>set, the, shape, to, semi, transparent, by, calling, set_trans, 5</code></p>
</li>
<li><p>&#x7B80;&#x5355;&#x5206;&#x6790;&#x5668;</p>
<p>&#x7B80;&#x5355;&#x5206;&#x6790;&#x5668;&#x5728;&#x4EFB;&#x4F55;&#x4E0D;&#x662F;&#x5B57;&#x6BCD;&#x7684;&#x5730;&#x65B9;&#x5206;&#x9694;&#x6587;&#x672C;&#xFF0C;&#x5C06;&#x8BCD;&#x6761;&#x5C0F;&#x5199;&#x3002;&#x5B83;&#x4F1A;&#x4EA7;&#x751F;<code>set, the, shape, to, semi, transparent, by, calling, set, trans</code></p>
</li>
<li><p>&#x7A7A;&#x683C;&#x5206;&#x6790;&#x5668;</p>
<p>&#x7A7A;&#x683C;&#x5206;&#x6790;&#x5668;&#x5728;&#x7A7A;&#x683C;&#x7684;&#x5730;&#x65B9;&#x5212;&#x5206;&#x6587;&#x672C;&#x3002;&#x5B83;&#x4F1A;&#x4EA7;&#x751F;<code>Set, the, shape, to, semi-transparent, by, calling, set_trans(5)</code></p>
</li>
<li><p>&#x8BED;&#x8A00;&#x5206;&#x6790;&#x5668;</p>
<p>&#x7279;&#x5B9A;&#x8BED;&#x8A00;&#x5206;&#x6790;&#x5668;&#x53EF;&#x7528;&#x4E8E; <a href="https://www.elastic.co/guide/en/elasticsearch/reference/5.6/analysis-lang-analyzer.html" target="_blank">&#x5F88;&#x591A;&#x8BED;&#x8A00;</a>&#x3002;&#x5B83;&#x4EEC;&#x53EF;&#x4EE5;&#x8003;&#x8651;&#x6307;&#x5B9A;&#x8BED;&#x8A00;&#x7684;&#x7279;&#x70B9;&#x3002;&#x4F8B;&#x5982;&#xFF0C; <code>&#x82F1;&#x8BED;</code> &#x5206;&#x6790;&#x5668;&#x9644;&#x5E26;&#x4E86;&#x4E00;&#x7EC4;&#x82F1;&#x8BED;&#x65E0;&#x7528;&#x8BCD;&#xFF08;&#x5E38;&#x7528;&#x5355;&#x8BCD;&#xFF0C;&#x4F8B;&#x5982; <code>and</code> &#x6216;&#x8005; <code>the</code> &#xFF0C;&#x5B83;&#x4EEC;&#x5BF9;&#x76F8;&#x5173;&#x6027;&#x6CA1;&#x6709;&#x591A;&#x5C11;&#x5F71;&#x54CD;&#xFF09;&#xFF0C;&#x5B83;&#x4EEC;&#x4F1A;&#x88AB;&#x5220;&#x9664;&#x3002; &#x7531;&#x4E8E;&#x7406;&#x89E3;&#x82F1;&#x8BED;&#x8BED;&#x6CD5;&#x7684;&#x89C4;&#x5219;&#xFF0C;&#x8FD9;&#x4E2A;&#x5206;&#x8BCD;&#x5668;&#x53EF;&#x4EE5;&#x63D0;&#x53D6;&#x82F1;&#x8BED;&#x5355;&#x8BCD;&#x7684; <em>&#x8BCD;&#x5E72;</em> &#x3002;<code>&#x82F1;&#x8BED;</code> &#x5206;&#x8BCD;&#x5668;&#x4F1A;&#x4EA7;&#x751F;&#x4E0B;&#x9762;&#x7684;&#x8BCD;&#x6761;&#xFF1A;<code>set, shape, semi, transpar, call, set_tran, 5</code>&#x6CE8;&#x610F;&#x770B; <code>transparent</code>&#x3001; <code>calling</code> &#x548C; <code>set_trans</code> &#x5DF2;&#x7ECF;&#x53D8;&#x4E3A;&#x8BCD;&#x6839;&#x683C;&#x5F0F;&#x3002;</p>
</li>
</ul>
<p><strong>&#x4EC0;&#x4E48;&#x65F6;&#x5019;&#x4F7F;&#x7528;&#x5206;&#x6790;&#x5668;</strong></p>
<p>&#x5F53;&#x6211;&#x4EEC; <em>&#x7D22;&#x5F15;</em> &#x4E00;&#x4E2A;&#x6587;&#x6863;&#xFF0C;&#x5B83;&#x7684;&#x5168;&#x6587;&#x57DF;&#x88AB;&#x5206;&#x6790;&#x6210;&#x8BCD;&#x6761;&#x4EE5;&#x7528;&#x6765;&#x521B;&#x5EFA;&#x5012;&#x6392;&#x7D22;&#x5F15;&#x3002; &#x4F46;&#x662F;&#xFF0C;&#x5F53;&#x6211;&#x4EEC;&#x5728;&#x5168;&#x6587;&#x57DF; <em>&#x641C;&#x7D22;</em> &#x7684;&#x65F6;&#x5019;&#xFF0C;&#x6211;&#x4EEC;&#x9700;&#x8981;&#x5C06;&#x67E5;&#x8BE2;&#x5B57;&#x7B26;&#x4E32;&#x901A;&#x8FC7; <em>&#x76F8;&#x540C;&#x7684;&#x5206;&#x6790;&#x8FC7;&#x7A0B;</em> &#xFF0C;&#x4EE5;&#x4FDD;&#x8BC1;&#x6211;&#x4EEC;&#x641C;&#x7D22;&#x7684;&#x8BCD;&#x6761;&#x683C;&#x5F0F;&#x4E0E;&#x7D22;&#x5F15;&#x4E2D;&#x7684;&#x8BCD;&#x6761;&#x683C;&#x5F0F;&#x4E00;&#x81F4;&#x3002;</p>
<p>&#x5168;&#x6587;&#x67E5;&#x8BE2;&#xFF0C;&#x7406;&#x89E3;&#x6BCF;&#x4E2A;&#x57DF;&#x662F;&#x5982;&#x4F55;&#x5B9A;&#x4E49;&#x7684;&#xFF0C;&#x56E0;&#x6B64;&#x5B83;&#x4EEC;&#x53EF;&#x4EE5;&#x505A; &#x6B63;&#x786E;&#x7684;&#x4E8B;&#xFF1A;</p>
<ul>
<li>&#x5F53;&#x4F60;&#x67E5;&#x8BE2;&#x4E00;&#x4E2A; <em>&#x5168;&#x6587;</em> &#x57DF;&#x65F6;&#xFF0C; &#x4F1A;&#x5BF9;&#x67E5;&#x8BE2;&#x5B57;&#x7B26;&#x4E32;&#x5E94;&#x7528;&#x76F8;&#x540C;&#x7684;&#x5206;&#x6790;&#x5668;&#xFF0C;&#x4EE5;&#x4EA7;&#x751F;&#x6B63;&#x786E;&#x7684;&#x641C;&#x7D22;&#x8BCD;&#x6761;&#x5217;&#x8868;&#x3002;</li>
<li>&#x5F53;&#x4F60;&#x67E5;&#x8BE2;&#x4E00;&#x4E2A; <em>&#x7CBE;&#x786E;&#x503C;</em> &#x57DF;&#x65F6;&#xFF0C;&#x4E0D;&#x4F1A;&#x5206;&#x6790;&#x67E5;&#x8BE2;&#x5B57;&#x7B26;&#x4E32;&#xFF0C; &#x800C;&#x662F;&#x641C;&#x7D22;&#x4F60;&#x6307;&#x5B9A;&#x7684;&#x7CBE;&#x786E;&#x503C;&#x3002;</li>
</ul>
<p>&#x73B0;&#x5728;&#x4F60;&#x53EF;&#x4EE5;&#x7406;&#x89E3;&#x5728; <a href="https://www.elastic.co/guide/cn/elasticsearch/guide/current/mapping-analysis.html" target="_blank">&#x5F00;&#x59CB;&#x7AE0;&#x8282;</a> &#x7684;&#x67E5;&#x8BE2;&#x4E3A;&#x4EC0;&#x4E48;&#x8FD4;&#x56DE;&#x90A3;&#x6837;&#x7684;&#x7ED3;&#x679C;&#xFF1A;</p>
<ul>
<li><code>date</code> &#x57DF;&#x5305;&#x542B;&#x4E00;&#x4E2A;&#x7CBE;&#x786E;&#x503C;&#xFF1A;&#x5355;&#x72EC;&#x7684;&#x8BCD;&#x6761; <code>2014-09-15</code>&#x3002;</li>
<li><code>_all</code> &#x57DF;&#x662F;&#x4E00;&#x4E2A;&#x5168;&#x6587;&#x57DF;&#xFF0C;&#x6240;&#x4EE5;&#x5206;&#x8BCD;&#x8FDB;&#x7A0B;&#x5C06;&#x65E5;&#x671F;&#x8F6C;&#x5316;&#x4E3A;&#x4E09;&#x4E2A;&#x8BCD;&#x6761;&#xFF1A; <code>2014</code>&#xFF0C; <code>09</code>&#xFF0C; &#x548C; <code>15</code>&#x3002;</li>
</ul>
<p>&#x5F53;&#x6211;&#x4EEC;&#x5728; <code>_all</code> &#x57DF;&#x67E5;&#x8BE2; <code>2014</code>&#xFF0C;&#x5B83;&#x5339;&#x914D;&#x6240;&#x6709;&#x7684;12&#x6761;&#x63A8;&#x6587;&#xFF0C;&#x56E0;&#x4E3A;&#x5B83;&#x4EEC;&#x90FD;&#x542B;&#x6709; <code>2014</code> &#xFF1A;</p>
<pre><code class="lang-sh">GET /_search?q=2014              <span class="hljs-comment"># 12 results</span>
</code></pre>
<p>&#x5F53;&#x6211;&#x4EEC;&#x5728; <code>_all</code> &#x57DF;&#x67E5;&#x8BE2; <code>2014-09-15</code>&#xFF0C;&#x5B83;&#x9996;&#x5148;&#x5206;&#x6790;&#x67E5;&#x8BE2;&#x5B57;&#x7B26;&#x4E32;&#xFF0C;&#x4EA7;&#x751F;&#x5339;&#x914D; <code>2014</code>&#xFF0C; <code>09</code>&#xFF0C; &#x6216; <code>15</code> &#x4E2D; <em>&#x4EFB;&#x610F;</em> &#x8BCD;&#x6761;&#x7684;&#x67E5;&#x8BE2;&#x3002;&#x8FD9;&#x4E5F;&#x4F1A;&#x5339;&#x914D;&#x6240;&#x6709;12&#x6761;&#x63A8;&#x6587;&#xFF0C;&#x56E0;&#x4E3A;&#x5B83;&#x4EEC;&#x90FD;&#x542B;&#x6709; <code>2014</code> &#xFF1A;</p>
<pre><code class="lang-sh">GET /_search?q=2014-09-15        <span class="hljs-comment"># 12 results !</span>
</code></pre>
<p>&#x5F53;&#x6211;&#x4EEC;&#x5728; <code>date</code> &#x57DF;&#x67E5;&#x8BE2; <code>2014-09-15</code>&#xFF0C;&#x5B83;&#x5BFB;&#x627E; <em>&#x7CBE;&#x786E;</em> &#x65E5;&#x671F;&#xFF0C;&#x53EA;&#x627E;&#x5230;&#x4E00;&#x4E2A;&#x63A8;&#x6587;&#xFF1A;</p>
<pre><code class="lang-sh">GET /_search?q=date:2014-09-15   <span class="hljs-comment"># 1  result</span>
</code></pre>
<p>&#x5F53;&#x6211;&#x4EEC;&#x5728; <code>date</code> &#x57DF;&#x67E5;&#x8BE2; <code>2014</code>&#xFF0C;&#x5B83;&#x627E;&#x4E0D;&#x5230;&#x4EFB;&#x4F55;&#x6587;&#x6863;&#xFF0C;&#x56E0;&#x4E3A;&#x6CA1;&#x6709;&#x6587;&#x6863;&#x542B;&#x6709;&#x8FD9;&#x4E2A;&#x7CBE;&#x786E;&#x65E5;&#x5FD7;&#xFF1A;</p>
<pre><code class="lang-sh">GET /_search?q=date:2014         <span class="hljs-comment"># 0  results !</span>
</code></pre>
<p><strong>&#x6D4B;&#x8BD5;&#x5206;&#x6790;&#x5668;</strong></p>
<p>&#x6709;&#x4E9B;&#x65F6;&#x5019;&#x5F88;&#x96BE;&#x7406;&#x89E3;&#x5206;&#x8BCD;&#x7684;&#x8FC7;&#x7A0B;&#x548C;&#x5B9E;&#x9645;&#x88AB;&#x5B58;&#x50A8;&#x5230;&#x7D22;&#x5F15;&#x4E2D;&#x7684;&#x8BCD;&#x6761;&#xFF0C;&#x7279;&#x522B;&#x662F;&#x4F60;&#x521A;&#x63A5;&#x89E6; Elasticsearch&#x3002;&#x4E3A;&#x4E86;&#x7406;&#x89E3;&#x53D1;&#x751F;&#x4E86;&#x4EC0;&#x4E48;&#xFF0C;&#x4F60;&#x53EF;&#x4EE5;&#x4F7F;&#x7528; <code>analyze</code> API &#x6765;&#x770B;&#x6587;&#x672C;&#x662F;&#x5982;&#x4F55;&#x88AB;&#x5206;&#x6790;&#x7684;&#x3002;&#x5728;&#x6D88;&#x606F;&#x4F53;&#x91CC;&#xFF0C;&#x6307;&#x5B9A;&#x5206;&#x6790;&#x5668;&#x548C;&#x8981;&#x5206;&#x6790;&#x7684;&#x6587;&#x672C;&#xFF1A;</p>
<pre><code class="lang-js">GET /_analyze
{
  <span class="hljs-string">&quot;analyzer&quot;</span>: <span class="hljs-string">&quot;standard&quot;</span>,
  <span class="hljs-string">&quot;text&quot;</span>: <span class="hljs-string">&quot;Text to analyze&quot;</span>
}
</code></pre>
<p>&#x62F7;&#x8D1D;&#x4E3A; CURL<a href="http://localhost:5601/app/sense/?load_from=https://www.elastic.co/guide/cn/elasticsearch/guide/current/snippets/052_Mapping_Analysis/40_Analyze.json" target="_blank">&#x5728; SENSE &#x4E2D;&#x67E5;&#x770B;</a> </p>
<p>&#x7ED3;&#x679C;&#x4E2D;&#x6BCF;&#x4E2A;&#x5143;&#x7D20;&#x4EE3;&#x8868;&#x4E00;&#x4E2A;&#x5355;&#x72EC;&#x7684;&#x8BCD;&#x6761;&#xFF1A;</p>
<pre><code class="lang-js">{
   <span class="hljs-string">&quot;tokens&quot;</span>: [
      {
         <span class="hljs-string">&quot;token&quot;</span>:        <span class="hljs-string">&quot;text&quot;</span>,
         <span class="hljs-string">&quot;start_offset&quot;</span>: <span class="hljs-number">0</span>,
         <span class="hljs-string">&quot;end_offset&quot;</span>:   <span class="hljs-number">4</span>,
         <span class="hljs-string">&quot;type&quot;</span>:         <span class="hljs-string">&quot;&lt;ALPHANUM&gt;&quot;</span>,
         <span class="hljs-string">&quot;position&quot;</span>:     <span class="hljs-number">1</span>
      },
      {
         <span class="hljs-string">&quot;token&quot;</span>:        <span class="hljs-string">&quot;to&quot;</span>,
         <span class="hljs-string">&quot;start_offset&quot;</span>: <span class="hljs-number">5</span>,
         <span class="hljs-string">&quot;end_offset&quot;</span>:   <span class="hljs-number">7</span>,
         <span class="hljs-string">&quot;type&quot;</span>:         <span class="hljs-string">&quot;&lt;ALPHANUM&gt;&quot;</span>,
         <span class="hljs-string">&quot;position&quot;</span>:     <span class="hljs-number">2</span>
      },
      {
         <span class="hljs-string">&quot;token&quot;</span>:        <span class="hljs-string">&quot;analyze&quot;</span>,
         <span class="hljs-string">&quot;start_offset&quot;</span>: <span class="hljs-number">8</span>,
         <span class="hljs-string">&quot;end_offset&quot;</span>:   <span class="hljs-number">15</span>,
         <span class="hljs-string">&quot;type&quot;</span>:         <span class="hljs-string">&quot;&lt;ALPHANUM&gt;&quot;</span>,
         <span class="hljs-string">&quot;position&quot;</span>:     <span class="hljs-number">3</span>
      }
   ]
}
</code></pre>
<p><code>token</code> &#x662F;&#x5B9E;&#x9645;&#x5B58;&#x50A8;&#x5230;&#x7D22;&#x5F15;&#x4E2D;&#x7684;&#x8BCD;&#x6761;&#x3002; <code>position</code> &#x6307;&#x660E;&#x8BCD;&#x6761;&#x5728;&#x539F;&#x59CB;&#x6587;&#x672C;&#x4E2D;&#x51FA;&#x73B0;&#x7684;&#x4F4D;&#x7F6E;&#x3002; <code>start_offset</code> &#x548C; <code>end_offset</code> &#x6307;&#x660E;&#x5B57;&#x7B26;&#x5728;&#x539F;&#x59CB;&#x5B57;&#x7B26;&#x4E32;&#x4E2D;&#x7684;&#x4F4D;&#x7F6E;&#x3002;</p>
<blockquote>
<p> <img src="assets/tip.png" alt="&#x63D0;&#x793A;">  &#x6BCF;&#x4E2A;&#x5206;&#x6790;&#x5668;&#x7684; <code>type</code> &#x503C;&#x90FD;&#x4E0D;&#x4E00;&#x6837;&#xFF0C;&#x53EF;&#x4EE5;&#x5FFD;&#x7565;&#x5B83;&#x4EEC;&#x3002;&#x5B83;&#x4EEC;&#x5728;Elasticsearch&#x4E2D;&#x7684;&#x552F;&#x4E00;&#x4F5C;&#x7528;&#x5728;&#x4E8E;<a href="https://www.elastic.co/guide/en/elasticsearch/reference/5.6/analysis-keep-types-tokenfilter.html" target="_blank"><code>keep_types</code> token &#x8FC7;&#x6EE4;&#x5668;</a>&#x3002;</p>
</blockquote>
<p><code>analyze</code> API &#x662F;&#x4E00;&#x4E2A;&#x6709;&#x7528;&#x7684;&#x5DE5;&#x5177;&#xFF0C;&#x5B83;&#x6709;&#x52A9;&#x4E8E;&#x6211;&#x4EEC;&#x7406;&#x89E3;Elasticsearch&#x7D22;&#x5F15;&#x5185;&#x90E8;&#x53D1;&#x751F;&#x4E86;&#x4EC0;&#x4E48;&#xFF0C;&#x968F;&#x7740;&#x6DF1;&#x5165;&#xFF0C;&#x6211;&#x4EEC;&#x4F1A;&#x8FDB;&#x4E00;&#x6B65;&#x8BA8;&#x8BBA;&#x5B83;&#x3002;</p>
<p><strong>&#x6307;&#x5B9A;&#x5206;&#x6790;&#x5668;</strong></p>
<p>&#x5F53;Elasticsearch&#x5728;&#x4F60;&#x7684;&#x6587;&#x6863;&#x4E2D;&#x68C0;&#x6D4B;&#x5230;&#x4E00;&#x4E2A;&#x65B0;&#x7684;&#x5B57;&#x7B26;&#x4E32;&#x57DF; &#xFF0C;&#x5B83;&#x4F1A;&#x81EA;&#x52A8;&#x8BBE;&#x7F6E;&#x5176;&#x4E3A;&#x4E00;&#x4E2A;&#x5168;&#x6587; <code>&#x5B57;&#x7B26;&#x4E32;</code> &#x57DF;&#xFF0C;&#x4F7F;&#x7528; <code>&#x6807;&#x51C6;</code> &#x5206;&#x6790;&#x5668;&#x5BF9;&#x5B83;&#x8FDB;&#x884C;&#x5206;&#x6790;&#x3002;</p>
<p>&#x4F60;&#x4E0D;&#x5E0C;&#x671B;&#x603B;&#x662F;&#x8FD9;&#x6837;&#x3002;&#x53EF;&#x80FD;&#x4F60;&#x60F3;&#x4F7F;&#x7528;&#x4E00;&#x4E2A;&#x4E0D;&#x540C;&#x7684;&#x5206;&#x6790;&#x5668;&#xFF0C;&#x9002;&#x7528;&#x4E8E;&#x4F60;&#x7684;&#x6570;&#x636E;&#x4F7F;&#x7528;&#x7684;&#x8BED;&#x8A00;&#x3002;&#x6709;&#x65F6;&#x5019;&#x4F60;&#x60F3;&#x8981;&#x4E00;&#x4E2A;&#x5B57;&#x7B26;&#x4E32;&#x57DF;&#x5C31;&#x662F;&#x4E00;&#x4E2A;&#x5B57;&#x7B26;&#x4E32;&#x57DF;--&#x4E0D;&#x4F7F;&#x7528;&#x5206;&#x6790;&#xFF0C;&#x76F4;&#x63A5;&#x7D22;&#x5F15;&#x4F60;&#x4F20;&#x5165;&#x7684;&#x7CBE;&#x786E;&#x503C;&#xFF0C;&#x4F8B;&#x5982;&#x7528;&#x6237;ID&#x6216;&#x8005;&#x4E00;&#x4E2A;&#x5185;&#x90E8;&#x7684;&#x72B6;&#x6001;&#x57DF;&#x6216;&#x6807;&#x7B7E;&#x3002;</p>
<p>&#x8981;&#x505A;&#x5230;&#x8FD9;&#x4E00;&#x70B9;&#xFF0C;&#x6211;&#x4EEC;&#x5FC5;&#x987B;&#x624B;&#x52A8;&#x6307;&#x5B9A;&#x8FD9;&#x4E9B;&#x57DF;&#x7684;&#x6620;&#x5C04;&#x3002;</p>
<h3 id="&#x6620;&#x5C04;"><a name="&#x6620;&#x5C04;" class="anchor-navigation-ex-anchor" href="#&#x6620;&#x5C04;"><i class="fa fa-link" aria-hidden="true"></i></a>&#x6620;&#x5C04;</h3>
<p>&#x4E3A;&#x4E86;&#x80FD;&#x591F;&#x5C06;&#x65F6;&#x95F4;&#x57DF;&#x89C6;&#x4E3A;&#x65F6;&#x95F4;&#xFF0C;&#x6570;&#x5B57;&#x57DF;&#x89C6;&#x4E3A;&#x6570;&#x5B57;&#xFF0C;&#x5B57;&#x7B26;&#x4E32;&#x57DF;&#x89C6;&#x4E3A;&#x5168;&#x6587;&#x6216;&#x7CBE;&#x786E;&#x503C;&#x5B57;&#x7B26;&#x4E32;&#xFF0C; Elasticsearch &#x9700;&#x8981;&#x77E5;&#x9053;&#x6BCF;&#x4E2A;&#x57DF;&#x4E2D;&#x6570;&#x636E;&#x7684;&#x7C7B;&#x578B;&#x3002;&#x8FD9;&#x4E2A;&#x4FE1;&#x606F;&#x5305;&#x542B;&#x5728;&#x6620;&#x5C04;&#x4E2D;&#x3002;</p>
<p>&#x5982; <a href="https://www.elastic.co/guide/cn/elasticsearch/guide/current/data-in-data-out.html" target="_blank"><em>&#x6570;&#x636E;&#x8F93;&#x5165;&#x548C;&#x8F93;&#x51FA;</em></a> &#x4E2D;&#x89E3;&#x91CA;&#x7684;&#xFF0C; &#x7D22;&#x5F15;&#x4E2D;&#x6BCF;&#x4E2A;&#x6587;&#x6863;&#x90FD;&#x6709; <em>&#x7C7B;&#x578B;</em> &#x3002;&#x6BCF;&#x79CD;&#x7C7B;&#x578B;&#x90FD;&#x6709;&#x5B83;&#x81EA;&#x5DF1;&#x7684; <em>&#x6620;&#x5C04;</em> &#xFF0C;&#x6216;&#x8005; <em>&#x6A21;&#x5F0F;&#x5B9A;&#x4E49;</em>&#x3002;&#x6620;&#x5C04;&#x5B9A;&#x4E49;&#x4E86;&#x7C7B;&#x578B;&#x4E2D;&#x7684;&#x57DF;&#xFF0C;&#x6BCF;&#x4E2A;&#x57DF;&#x7684;&#x6570;&#x636E;&#x7C7B;&#x578B;&#xFF0C;&#x4EE5;&#x53CA;Elasticsearch&#x5982;&#x4F55;&#x5904;&#x7406;&#x8FD9;&#x4E9B;&#x57DF;&#x3002;&#x6620;&#x5C04;&#x4E5F;&#x7528;&#x4E8E;&#x914D;&#x7F6E;&#x4E0E;&#x7C7B;&#x578B;&#x6709;&#x5173;&#x7684;&#x5143;&#x6570;&#x636E;&#x3002;</p>
<p>&#x6211;&#x4EEC;&#x4F1A;&#x5728; <a href="https://www.elastic.co/guide/cn/elasticsearch/guide/current/mapping.html" target="_blank">&#x7C7B;&#x578B;&#x548C;&#x6620;&#x5C04;</a> &#x8BE6;&#x7EC6;&#x8BA8;&#x8BBA;&#x6620;&#x5C04;&#x3002;&#x672C;&#x8282;&#xFF0C;&#x6211;&#x4EEC;&#x53EA;&#x8BA8;&#x8BBA;&#x8DB3;&#x591F;&#x8BA9;&#x4F60;&#x5165;&#x95E8;&#x7684;&#x5185;&#x5BB9;&#x3002;</p>
<p><strong>&#x6838;&#x5FC3;&#x7B80;&#x5355;&#x57DF;&#x7C7B;&#x578B;</strong></p>
<p>Elasticsearch &#x652F;&#x6301; &#x5982;&#x4E0B;&#x7B80;&#x5355;&#x57DF;&#x7C7B;&#x578B;&#xFF1A;</p>
<ul>
<li>&#x5B57;&#x7B26;&#x4E32;: <code>string</code></li>
<li>&#x6574;&#x6570; : <code>byte</code>, <code>short</code>, <code>integer</code>, <code>long</code></li>
<li>&#x6D6E;&#x70B9;&#x6570;: <code>float</code>, <code>double</code></li>
<li>&#x5E03;&#x5C14;&#x578B;: <code>boolean</code></li>
<li>&#x65E5;&#x671F;: <code>date</code></li>
</ul>
<p>&#x5F53;&#x4F60;&#x7D22;&#x5F15;&#x4E00;&#x4E2A;&#x5305;&#x542B;&#x65B0;&#x57DF;&#x7684;&#x6587;&#x6863;--&#x4E4B;&#x524D;&#x672A;&#x66FE;&#x51FA;&#x73B0;-- Elasticsearch &#x4F1A;&#x4F7F;&#x7528; <a href="https://www.elastic.co/guide/cn/elasticsearch/guide/current/dynamic-mapping.html" target="_blank"><em>&#x52A8;&#x6001;&#x6620;&#x5C04;</em></a> &#xFF0C;&#x901A;&#x8FC7;JSON&#x4E2D;&#x57FA;&#x672C;&#x6570;&#x636E;&#x7C7B;&#x578B;&#xFF0C;&#x5C1D;&#x8BD5;&#x731C;&#x6D4B;&#x57DF;&#x7C7B;&#x578B;&#xFF0C;&#x4F7F;&#x7528;&#x5982;&#x4E0B;&#x89C4;&#x5219;&#xFF1A;</p>
<table>
<thead>
<tr>
<th><strong>JSON type</strong></th>
<th><strong>&#x57DF; type</strong></th>
</tr>
</thead>
<tbody>
<tr>
<td>&#x5E03;&#x5C14;&#x578B;: <code>true</code> &#x6216;&#x8005; <code>false</code></td>
<td><code>boolean</code></td>
</tr>
<tr>
<td>&#x6574;&#x6570;: <code>123</code></td>
<td><code>long</code></td>
</tr>
<tr>
<td>&#x6D6E;&#x70B9;&#x6570;: <code>123.45</code></td>
<td><code>double</code></td>
</tr>
<tr>
<td>&#x5B57;&#x7B26;&#x4E32;&#xFF0C;&#x6709;&#x6548;&#x65E5;&#x671F;: <code>2014-09-15</code></td>
<td><code>date</code></td>
</tr>
<tr>
<td>&#x5B57;&#x7B26;&#x4E32;: <code>foo bar</code></td>
<td><code>string</code></td>
</tr>
</tbody>
</table>
<blockquote>
<p> <img src="assets/note.png" alt="&#x6CE8;&#x610F;">  &#x8FD9;&#x610F;&#x5473;&#x7740;&#x5982;&#x679C;&#x4F60;&#x901A;&#x8FC7;&#x5F15;&#x53F7;( <code>&quot;123&quot;</code> )&#x7D22;&#x5F15;&#x4E00;&#x4E2A;&#x6570;&#x5B57;&#xFF0C;&#x5B83;&#x4F1A;&#x88AB;&#x6620;&#x5C04;&#x4E3A; <code>string</code> &#x7C7B;&#x578B;&#xFF0C;&#x800C;&#x4E0D;&#x662F; <code>long</code> &#x3002;&#x4F46;&#x662F;&#xFF0C;&#x5982;&#x679C;&#x8FD9;&#x4E2A;&#x57DF;&#x5DF2;&#x7ECF;&#x6620;&#x5C04;&#x4E3A; <code>long</code> &#xFF0C;&#x90A3;&#x4E48; Elasticsearch &#x4F1A;&#x5C1D;&#x8BD5;&#x5C06;&#x8FD9;&#x4E2A;&#x5B57;&#x7B26;&#x4E32;&#x8F6C;&#x5316;&#x4E3A; long &#xFF0C;&#x5982;&#x679C;&#x65E0;&#x6CD5;&#x8F6C;&#x5316;&#xFF0C;&#x5219;&#x629B;&#x51FA;&#x4E00;&#x4E2A;&#x5F02;&#x5E38;&#x3002;</p>
</blockquote>
<p><strong>&#x67E5;&#x770B;&#x6620;&#x5C04;</strong></p>
<p>&#x901A;&#x8FC7; <code>/_mapping</code> &#xFF0C;&#x6211;&#x4EEC;&#x53EF;&#x4EE5;&#x67E5;&#x770B; Elasticsearch &#x5728;&#x4E00;&#x4E2A;&#x6216;&#x591A;&#x4E2A;&#x7D22;&#x5F15;&#x4E2D;&#x7684;&#x4E00;&#x4E2A;&#x6216;&#x591A;&#x4E2A;&#x7C7B;&#x578B;&#x7684;&#x6620;&#x5C04; &#x3002;&#x5728; <a href="https://www.elastic.co/guide/cn/elasticsearch/guide/current/mapping-analysis.html" target="_blank">&#x5F00;&#x59CB;&#x7AE0;&#x8282;</a> &#xFF0C;&#x6211;&#x4EEC;&#x5DF2;&#x7ECF;&#x53D6;&#x5F97;&#x7D22;&#x5F15; <code>gb</code> &#x4E2D;&#x7C7B;&#x578B; <code>tweet</code> &#x7684;&#x6620;&#x5C04;&#xFF1A;</p>
<pre><code class="lang-js">GET /gb/_mapping/tweet
</code></pre>
<p>Elasticsearch &#x6839;&#x636E;&#x6211;&#x4EEC;&#x7D22;&#x5F15;&#x7684;&#x6587;&#x6863;&#xFF0C;&#x4E3A;&#x57DF;(&#x79F0;&#x4E3A; <em>&#x5C5E;&#x6027;</em> )&#x52A8;&#x6001;&#x751F;&#x6210;&#x7684;&#x6620;&#x5C04;&#x3002;</p>
<pre><code class="lang-js">{
   <span class="hljs-string">&quot;gb&quot;</span>: {
      <span class="hljs-string">&quot;mappings&quot;</span>: {
         <span class="hljs-string">&quot;tweet&quot;</span>: {
            <span class="hljs-string">&quot;properties&quot;</span>: {
               <span class="hljs-string">&quot;date&quot;</span>: {
                  <span class="hljs-string">&quot;type&quot;</span>: <span class="hljs-string">&quot;date&quot;</span>,
                  <span class="hljs-string">&quot;format&quot;</span>: <span class="hljs-string">&quot;strict_date_optional_time||epoch_millis&quot;</span>
               },
               <span class="hljs-string">&quot;name&quot;</span>: {
                  <span class="hljs-string">&quot;type&quot;</span>: <span class="hljs-string">&quot;string&quot;</span>
               },
               <span class="hljs-string">&quot;tweet&quot;</span>: {
                  <span class="hljs-string">&quot;type&quot;</span>: <span class="hljs-string">&quot;string&quot;</span>
               },
               <span class="hljs-string">&quot;user_id&quot;</span>: {
                  <span class="hljs-string">&quot;type&quot;</span>: <span class="hljs-string">&quot;long&quot;</span>
               }
            }
         }
      }
   }
}
</code></pre>
<blockquote>
<p> <img src="assets/tip.png" alt="&#x63D0;&#x793A;">  &#x9519;&#x8BEF;&#x7684;&#x6620;&#x5C04;&#xFF0C;&#x4F8B;&#x5982; &#x5C06; <code>age</code> &#x57DF;&#x6620;&#x5C04;&#x4E3A; <code>string</code> &#x7C7B;&#x578B;&#xFF0C;&#x800C;&#x4E0D;&#x662F; <code>integer</code> &#xFF0C;&#x4F1A;&#x5BFC;&#x81F4;&#x67E5;&#x8BE2;&#x51FA;&#x73B0;&#x4EE4;&#x4EBA;&#x56F0;&#x60D1;&#x7684;&#x7ED3;&#x679C;&#x3002;</p>
</blockquote>
<p>&#x68C0;&#x67E5;&#x4E00;&#x4E0B;&#xFF01;&#x800C;&#x4E0D;&#x662F;&#x5047;&#x8BBE;&#x4F60;&#x7684;&#x6620;&#x5C04;&#x662F;&#x6B63;&#x786E;&#x7684;&#x3002;</p>
<p><strong>&#x81EA;&#x5B9A;&#x4E49;&#x57DF;&#x6620;&#x5C04;</strong></p>
<p>&#x5C3D;&#x7BA1;&#x5728;&#x5F88;&#x591A;&#x60C5;&#x51B5;&#x4E0B;&#x57FA;&#x672C;&#x57DF;&#x6570;&#x636E;&#x7C7B;&#x578B; &#x5DF2;&#x7ECF;&#x591F;&#x7528;&#xFF0C;&#x4F46;&#x4F60;&#x7ECF;&#x5E38;&#x9700;&#x8981;&#x4E3A;&#x5355;&#x72EC;&#x57DF;&#x81EA;&#x5B9A;&#x4E49;&#x6620;&#x5C04; &#xFF0C;&#x7279;&#x522B;&#x662F;&#x5B57;&#x7B26;&#x4E32;&#x57DF;&#x3002;&#x81EA;&#x5B9A;&#x4E49;&#x6620;&#x5C04;&#x5141;&#x8BB8;&#x4F60;&#x6267;&#x884C;&#x4E0B;&#x9762;&#x7684;&#x64CD;&#x4F5C;&#xFF1A;</p>
<ul>
<li>&#x5168;&#x6587;&#x5B57;&#x7B26;&#x4E32;&#x57DF;&#x548C;&#x7CBE;&#x786E;&#x503C;&#x5B57;&#x7B26;&#x4E32;&#x57DF;&#x7684;&#x533A;&#x522B;</li>
<li>&#x4F7F;&#x7528;&#x7279;&#x5B9A;&#x8BED;&#x8A00;&#x5206;&#x6790;&#x5668;</li>
<li>&#x4F18;&#x5316;&#x57DF;&#x4EE5;&#x9002;&#x5E94;&#x90E8;&#x5206;&#x5339;&#x914D;</li>
<li>&#x6307;&#x5B9A;&#x81EA;&#x5B9A;&#x4E49;&#x6570;&#x636E;&#x683C;&#x5F0F;</li>
<li>&#x8FD8;&#x6709;&#x66F4;&#x591A;</li>
</ul>
<p>&#x57DF;&#x6700;&#x91CD;&#x8981;&#x7684;&#x5C5E;&#x6027;&#x662F; <code>type</code> &#x3002;&#x5BF9;&#x4E8E;&#x4E0D;&#x662F; <code>string</code> &#x7684;&#x57DF;&#xFF0C;&#x4F60;&#x4E00;&#x822C;&#x53EA;&#x9700;&#x8981;&#x8BBE;&#x7F6E; <code>type</code> &#xFF1A;</p>
<pre><code class="lang-js">{
    <span class="hljs-string">&quot;number_of_clicks&quot;</span>: {
        <span class="hljs-string">&quot;type&quot;</span>: <span class="hljs-string">&quot;integer&quot;</span>
    }
}
</code></pre>
<p>&#x9ED8;&#x8BA4;&#xFF0C; <code>string</code> &#x7C7B;&#x578B;&#x57DF;&#x4F1A;&#x88AB;&#x8BA4;&#x4E3A;&#x5305;&#x542B;&#x5168;&#x6587;&#x3002;&#x5C31;&#x662F;&#x8BF4;&#xFF0C;&#x5B83;&#x4EEC;&#x7684;&#x503C;&#x5728;&#x7D22;&#x5F15;&#x524D;&#xFF0C;&#x4F1A;&#x901A;&#x8FC7; &#x4E00;&#x4E2A;&#x5206;&#x6790;&#x5668;&#xFF0C;&#x9488;&#x5BF9;&#x4E8E;&#x8FD9;&#x4E2A;&#x57DF;&#x7684;&#x67E5;&#x8BE2;&#x5728;&#x641C;&#x7D22;&#x524D;&#x4E5F;&#x4F1A;&#x7ECF;&#x8FC7;&#x4E00;&#x4E2A;&#x5206;&#x6790;&#x5668;&#x3002;</p>
<p><code>string</code> &#x57DF;&#x6620;&#x5C04;&#x7684;&#x4E24;&#x4E2A;&#x6700;&#x91CD;&#x8981; &#x5C5E;&#x6027;&#x662F; <code>index</code> &#x548C; <code>analyzer</code> &#x3002;</p>
<p><strong>index</strong></p>
<p><code>index</code> &#x5C5E;&#x6027;&#x63A7;&#x5236;&#x600E;&#x6837;&#x7D22;&#x5F15;&#x5B57;&#x7B26;&#x4E32;&#x3002;&#x5B83;&#x53EF;&#x4EE5;&#x662F;&#x4E0B;&#x9762;&#x4E09;&#x4E2A;&#x503C;&#xFF1A;</p>
<ul>
<li><p><code>analyzed</code></p>
<p>&#x9996;&#x5148;&#x5206;&#x6790;&#x5B57;&#x7B26;&#x4E32;&#xFF0C;&#x7136;&#x540E;&#x7D22;&#x5F15;&#x5B83;&#x3002;&#x6362;&#x53E5;&#x8BDD;&#x8BF4;&#xFF0C;&#x4EE5;&#x5168;&#x6587;&#x7D22;&#x5F15;&#x8FD9;&#x4E2A;&#x57DF;&#x3002;</p>
</li>
<li><p><code>not_analyzed</code></p>
<p>  &#x7D22;&#x5F15;&#x8FD9;&#x4E2A;&#x57DF;&#xFF0C;&#x6240;&#x4EE5;&#x5B83;&#x80FD;&#x591F;&#x88AB;&#x641C;&#x7D22;&#xFF0C;&#x4F46;&#x7D22;&#x5F15;&#x7684;&#x662F;&#x7CBE;&#x786E;&#x503C;&#x3002;&#x4E0D;&#x4F1A;&#x5BF9;&#x5B83;&#x8FDB;&#x884C;&#x5206;&#x6790;&#x3002;</p>
</li>
<li><p><code>no</code></p>
<p>&#x4E0D;&#x7D22;&#x5F15;&#x8FD9;&#x4E2A;&#x57DF;&#x3002;&#x8FD9;&#x4E2A;&#x57DF;&#x4E0D;&#x4F1A;&#x88AB;&#x641C;&#x7D22;&#x5230;&#x3002;</p>
</li>
</ul>
<p><code>string</code> &#x57DF; <code>index</code> &#x5C5E;&#x6027;&#x9ED8;&#x8BA4;&#x662F; <code>analyzed</code> &#x3002;&#x5982;&#x679C;&#x6211;&#x4EEC;&#x60F3;&#x6620;&#x5C04;&#x8FD9;&#x4E2A;&#x5B57;&#x6BB5;&#x4E3A;&#x4E00;&#x4E2A;&#x7CBE;&#x786E;&#x503C;&#xFF0C;&#x6211;&#x4EEC;&#x9700;&#x8981;&#x8BBE;&#x7F6E;&#x5B83;&#x4E3A; <code>not_analyzed</code> &#xFF1A;</p>
<pre><code class="lang-js">{
    <span class="hljs-string">&quot;tag&quot;</span>: {
        <span class="hljs-string">&quot;type&quot;</span>:     <span class="hljs-string">&quot;string&quot;</span>,
        <span class="hljs-string">&quot;index&quot;</span>:    <span class="hljs-string">&quot;not_analyzed&quot;</span>
    }
}
</code></pre>
<blockquote>
<p> <img src="assets/note.png" alt="&#x6CE8;&#x610F;">  &#x5176;&#x4ED6;&#x7B80;&#x5355;&#x7C7B;&#x578B;&#xFF08;&#x4F8B;&#x5982; <code>long</code> &#xFF0C; <code>double</code> &#xFF0C; <code>date</code> &#x7B49;&#xFF09;&#x4E5F;&#x63A5;&#x53D7; <code>index</code> &#x53C2;&#x6570;&#xFF0C;&#x4F46;&#x6709;&#x610F;&#x4E49;&#x7684;&#x503C;&#x53EA;&#x6709; <code>no</code> &#x548C; <code>not_analyzed</code> &#xFF0C; &#x56E0;&#x4E3A;&#x5B83;&#x4EEC;&#x6C38;&#x8FDC;&#x4E0D;&#x4F1A;&#x88AB;&#x5206;&#x6790;&#x3002;</p>
</blockquote>
<p><strong>analyzer</strong></p>
<p>&#x5BF9;&#x4E8E; <code>analyzed</code> &#x5B57;&#x7B26;&#x4E32;&#x57DF;&#xFF0C;&#x7528; <code>analyzer</code> &#x5C5E;&#x6027;&#x6307;&#x5B9A;&#x5728;&#x641C;&#x7D22;&#x548C;&#x7D22;&#x5F15;&#x65F6;&#x4F7F;&#x7528;&#x7684;&#x5206;&#x6790;&#x5668;&#x3002;&#x9ED8;&#x8BA4;&#xFF0C; Elasticsearch &#x4F7F;&#x7528; <code>standard</code> &#x5206;&#x6790;&#x5668;&#xFF0C; &#x4F46;&#x4F60;&#x53EF;&#x4EE5;&#x6307;&#x5B9A;&#x4E00;&#x4E2A;&#x5185;&#x7F6E;&#x7684;&#x5206;&#x6790;&#x5668;&#x66FF;&#x4EE3;&#x5B83;&#xFF0C;&#x4F8B;&#x5982; <code>whitespace</code> &#x3001; <code>simple</code> &#x548C; <code>english</code>&#xFF1A;</p>
<pre><code class="lang-js">{
    <span class="hljs-string">&quot;tweet&quot;</span>: {
        <span class="hljs-string">&quot;type&quot;</span>:     <span class="hljs-string">&quot;string&quot;</span>,
        <span class="hljs-string">&quot;analyzer&quot;</span>: <span class="hljs-string">&quot;english&quot;</span>
    }
}
</code></pre>
<p>&#x5728; <a href="https://www.elastic.co/guide/cn/elasticsearch/guide/current/custom-analyzers.html" target="_blank">&#x81EA;&#x5B9A;&#x4E49;&#x5206;&#x6790;&#x5668;</a> &#xFF0C;&#x6211;&#x4EEC;&#x4F1A;&#x5C55;&#x793A;&#x600E;&#x6837;&#x5B9A;&#x4E49;&#x548C;&#x4F7F;&#x7528;&#x81EA;&#x5B9A;&#x4E49;&#x5206;&#x6790;&#x5668;&#x3002;</p>
<p><strong>&#x66F4;&#x65B0;&#x6620;&#x5C04;</strong></p>
<p>&#x5F53;&#x4F60;&#x9996;&#x6B21; &#x521B;&#x5EFA;&#x4E00;&#x4E2A;&#x7D22;&#x5F15;&#x7684;&#x65F6;&#x5019;&#xFF0C;&#x53EF;&#x4EE5;&#x6307;&#x5B9A;&#x7C7B;&#x578B;&#x7684;&#x6620;&#x5C04;&#x3002;&#x4F60;&#x4E5F;&#x53EF;&#x4EE5;&#x4F7F;&#x7528; <code>/_mapping</code> &#x4E3A;&#x65B0;&#x7C7B;&#x578B;&#xFF08;&#x6216;&#x8005;&#x4E3A;&#x5B58;&#x5728;&#x7684;&#x7C7B;&#x578B;&#x66F4;&#x65B0;&#x6620;&#x5C04;&#xFF09;&#x589E;&#x52A0;&#x6620;&#x5C04;&#x3002;</p>
<blockquote>
<p> <img src="assets/note.png" alt="&#x6CE8;&#x610F;">   &#x5C3D;&#x7BA1;&#x4F60;&#x53EF;&#x4EE5; <em>&#x589E;&#x52A0;<em> &#x4E00;&#x4E2A;&#x5B58;&#x5728;&#x7684;&#x6620;&#x5C04;&#xFF0C;&#x4F60;&#x4E0D;&#x80FD; </em>&#x4FEE;&#x6539;</em> &#x5B58;&#x5728;&#x7684;&#x57DF;&#x6620;&#x5C04;&#x3002;&#x5982;&#x679C;&#x4E00;&#x4E2A;&#x57DF;&#x7684;&#x6620;&#x5C04;&#x5DF2;&#x7ECF;&#x5B58;&#x5728;&#xFF0C;&#x90A3;&#x4E48;&#x8BE5;&#x57DF;&#x7684;&#x6570;&#x636E;&#x53EF;&#x80FD;&#x5DF2;&#x7ECF;&#x88AB;&#x7D22;&#x5F15;&#x3002;&#x5982;&#x679C;&#x4F60;&#x610F;&#x56FE;&#x4FEE;&#x6539;&#x8FD9;&#x4E2A;&#x57DF;&#x7684;&#x6620;&#x5C04;&#xFF0C;&#x7D22;&#x5F15;&#x7684;&#x6570;&#x636E;&#x53EF;&#x80FD;&#x4F1A;&#x51FA;&#x9519;&#xFF0C;&#x4E0D;&#x80FD;&#x88AB;&#x6B63;&#x5E38;&#x7684;&#x641C;&#x7D22;&#x3002;</p>
</blockquote>
<p>&#x6211;&#x4EEC;&#x53EF;&#x4EE5;&#x66F4;&#x65B0;&#x4E00;&#x4E2A;&#x6620;&#x5C04;&#x6765;&#x6DFB;&#x52A0;&#x4E00;&#x4E2A;&#x65B0;&#x57DF;&#xFF0C;&#x4F46;&#x4E0D;&#x80FD;&#x5C06;&#x4E00;&#x4E2A;&#x5B58;&#x5728;&#x7684;&#x57DF;&#x4ECE; <code>analyzed</code> &#x6539;&#x4E3A; <code>not_analyzed</code> &#x3002;</p>
<p>&#x4E3A;&#x4E86;&#x63CF;&#x8FF0;&#x6307;&#x5B9A;&#x6620;&#x5C04;&#x7684;&#x4E24;&#x79CD;&#x65B9;&#x5F0F;&#xFF0C;&#x6211;&#x4EEC;&#x5148;&#x5220;&#x9664; <code>gd</code> &#x7D22;&#x5F15;&#xFF1A;</p>
<pre><code class="lang-sh">DELETE /gb
</code></pre>
<p>&#x7136;&#x540E;&#x521B;&#x5EFA;&#x4E00;&#x4E2A;&#x65B0;&#x7D22;&#x5F15;&#xFF0C;&#x6307;&#x5B9A; <code>tweet</code> &#x57DF;&#x4F7F;&#x7528; <code>english</code> &#x5206;&#x6790;&#x5668;&#xFF1A;</p>
<pre><code class="lang-js">PUT /gb                             &lt;<span class="hljs-number">1</span>&gt;
{
  <span class="hljs-string">&quot;mappings&quot;</span>: {
    <span class="hljs-string">&quot;tweet&quot;</span> : {
      <span class="hljs-string">&quot;properties&quot;</span> : {
        <span class="hljs-string">&quot;tweet&quot;</span> : {
          <span class="hljs-string">&quot;type&quot;</span> :    <span class="hljs-string">&quot;string&quot;</span>,
          <span class="hljs-string">&quot;analyzer&quot;</span>: <span class="hljs-string">&quot;english&quot;</span>
        },
        <span class="hljs-string">&quot;date&quot;</span> : {
          <span class="hljs-string">&quot;type&quot;</span> :   <span class="hljs-string">&quot;date&quot;</span>
        },
        <span class="hljs-string">&quot;name&quot;</span> : {
          <span class="hljs-string">&quot;type&quot;</span> :   <span class="hljs-string">&quot;string&quot;</span>
        },
        <span class="hljs-string">&quot;user_id&quot;</span> : {
          <span class="hljs-string">&quot;type&quot;</span> :   <span class="hljs-string">&quot;long&quot;</span>
        }
      }
    }
  }
}
</code></pre>
<blockquote>
<p> <img src="assets/1.png" alt="img">    &#x901A;&#x8FC7;&#x6D88;&#x606F;&#x4F53;&#x4E2D;&#x6307;&#x5B9A;&#x7684; <code>mappings</code> &#x521B;&#x5EFA;&#x4E86;&#x7D22;&#x5F15;&#x3002;  </p>
</blockquote>
<p>&#x7A0D;&#x540E;&#xFF0C;&#x6211;&#x4EEC;&#x51B3;&#x5B9A;&#x5728; <code>tweet</code> &#x6620;&#x5C04;&#x589E;&#x52A0;&#x4E00;&#x4E2A;&#x65B0;&#x7684;&#x540D;&#x4E3A; <code>tag</code> &#x7684; <code>not_analyzed</code> &#x7684;&#x6587;&#x672C;&#x57DF;&#xFF0C;&#x4F7F;&#x7528; <code>_mapping</code> &#xFF1A;</p>
<pre><code class="lang-js">PUT /gb/_mapping/tweet
{
  <span class="hljs-string">&quot;properties&quot;</span> : {
    <span class="hljs-string">&quot;tag&quot;</span> : {
      <span class="hljs-string">&quot;type&quot;</span> :    <span class="hljs-string">&quot;string&quot;</span>,
      <span class="hljs-string">&quot;index&quot;</span>:    <span class="hljs-string">&quot;not_analyzed&quot;</span>
    }
  }
}
</code></pre>
<p>&#x6CE8;&#x610F;&#xFF0C;&#x6211;&#x4EEC;&#x4E0D;&#x9700;&#x8981;&#x518D;&#x6B21;&#x5217;&#x51FA;&#x6240;&#x6709;&#x5DF2;&#x5B58;&#x5728;&#x7684;&#x57DF;&#xFF0C;&#x56E0;&#x4E3A;&#x65E0;&#x8BBA;&#x5982;&#x4F55;&#x6211;&#x4EEC;&#x90FD;&#x65E0;&#x6CD5;&#x6539;&#x53D8;&#x5B83;&#x4EEC;&#x3002;&#x65B0;&#x57DF;&#x5DF2;&#x7ECF;&#x88AB;&#x5408;&#x5E76;&#x5230;&#x5B58;&#x5728;&#x7684;&#x6620;&#x5C04;&#x4E2D;&#x3002;</p>
<p><strong>&#x6D4B;&#x8BD5;&#x6620;&#x5C04;</strong></p>
<p>&#x4F60;&#x53EF;&#x4EE5;&#x4F7F;&#x7528; <code>analyze</code> API &#x6D4B;&#x8BD5;&#x5B57;&#x7B26;&#x4E32;&#x57DF;&#x7684;&#x6620;&#x5C04;&#x3002;&#x6BD4;&#x8F83;&#x4E0B;&#x9762;&#x4E24;&#x4E2A;&#x8BF7;&#x6C42;&#x7684;&#x8F93;&#x51FA;&#xFF1A;</p>
<pre><code class="lang-js">GET /gb/_analyze
{
  <span class="hljs-string">&quot;field&quot;</span>: <span class="hljs-string">&quot;tweet&quot;</span>,
  <span class="hljs-string">&quot;text&quot;</span>: <span class="hljs-string">&quot;Black-cats&quot;</span>     &lt;<span class="hljs-number">1</span>&gt;
}

GET /gb/_analyze
{
  <span class="hljs-string">&quot;field&quot;</span>: <span class="hljs-string">&quot;tag&quot;</span>,
  <span class="hljs-string">&quot;text&quot;</span>: <span class="hljs-string">&quot;Black-cats&quot;</span>     &lt;<span class="hljs-number">2</span>&gt;
}
</code></pre>
<blockquote>
<p> <img src="assets/1.png" alt="img">  <img src="assets/2.png" alt="img">  &#x6D88;&#x606F;&#x4F53;&#x91CC;&#x9762;&#x4F20;&#x8F93;&#x6211;&#x4EEC;&#x60F3;&#x8981;&#x5206;&#x6790;&#x7684;&#x6587;&#x672C;&#x3002;  </p>
</blockquote>
<p><code>tweet</code> &#x57DF;&#x4EA7;&#x751F;&#x4E24;&#x4E2A;&#x8BCD;&#x6761; <code>black</code> &#x548C; <code>cat</code> &#xFF0C; <code>tag</code> &#x57DF;&#x4EA7;&#x751F;&#x5355;&#x72EC;&#x7684;&#x8BCD;&#x6761; <code>Black-cats</code> &#x3002;&#x6362;&#x53E5;&#x8BDD;&#x8BF4;&#xFF0C;&#x6211;&#x4EEC;&#x7684;&#x6620;&#x5C04;&#x6B63;&#x5E38;&#x5DE5;&#x4F5C;&#x3002;</p>
<h3 id="&#x590D;&#x6742;&#x6838;&#x5FC3;&#x57DF;&#x7C7B;&#x578B;"><a name="&#x590D;&#x6742;&#x6838;&#x5FC3;&#x57DF;&#x7C7B;&#x578B;" class="anchor-navigation-ex-anchor" href="#&#x590D;&#x6742;&#x6838;&#x5FC3;&#x57DF;&#x7C7B;&#x578B;"><i class="fa fa-link" aria-hidden="true"></i></a>&#x590D;&#x6742;&#x6838;&#x5FC3;&#x57DF;&#x7C7B;&#x578B;</h3>
<p>&#x9664;&#x4E86;&#x6211;&#x4EEC;&#x63D0;&#x5230;&#x7684;&#x7B80;&#x5355;&#x6807;&#x91CF;&#x6570;&#x636E;&#x7C7B;&#x578B;&#xFF0C; JSON &#x8FD8;&#x6709; <code>null</code> &#x503C;&#xFF0C;&#x6570;&#x7EC4;&#xFF0C;&#x548C;&#x5BF9;&#x8C61;&#xFF0C;&#x8FD9;&#x4E9B; Elasticsearch &#x90FD;&#x662F;&#x652F;&#x6301;&#x7684;&#x3002;</p>
<p><strong>&#x591A;&#x503C;&#x57DF;</strong></p>
<p>&#x5F88;&#x6709;&#x53EF;&#x80FD;&#xFF0C;&#x6211;&#x4EEC;&#x5E0C;&#x671B; <code>tag</code> &#x57DF; &#x5305;&#x542B;&#x591A;&#x4E2A;&#x6807;&#x7B7E;&#x3002;&#x6211;&#x4EEC;&#x53EF;&#x4EE5;&#x4EE5;&#x6570;&#x7EC4;&#x7684;&#x5F62;&#x5F0F;&#x7D22;&#x5F15;&#x6807;&#x7B7E;&#xFF1A;</p>
<pre><code class="lang-js">{ <span class="hljs-string">&quot;tag&quot;</span>: [ <span class="hljs-string">&quot;search&quot;</span>, <span class="hljs-string">&quot;nosql&quot;</span> ]}
</code></pre>
<p>&#x5BF9;&#x4E8E;&#x6570;&#x7EC4;&#xFF0C;&#x6CA1;&#x6709;&#x7279;&#x6B8A;&#x7684;&#x6620;&#x5C04;&#x9700;&#x6C42;&#x3002;&#x4EFB;&#x4F55;&#x57DF;&#x90FD;&#x53EF;&#x4EE5;&#x5305;&#x542B;0&#x3001;1&#x6216;&#x8005;&#x591A;&#x4E2A;&#x503C;&#xFF0C;&#x5C31;&#x50CF;&#x5168;&#x6587;&#x57DF;&#x5206;&#x6790;&#x5F97;&#x5230;&#x591A;&#x4E2A;&#x8BCD;&#x6761;&#x3002;</p>
<p>&#x8FD9;&#x6697;&#x793A; <em>&#x6570;&#x7EC4;&#x4E2D;&#x6240;&#x6709;&#x7684;&#x503C;&#x5FC5;&#x987B;&#x662F;&#x76F8;&#x540C;&#x6570;&#x636E;&#x7C7B;&#x578B;&#x7684;</em> &#x3002;&#x4F60;&#x4E0D;&#x80FD;&#x5C06;&#x65E5;&#x671F;&#x548C;&#x5B57;&#x7B26;&#x4E32;&#x6DF7;&#x5728;&#x4E00;&#x8D77;&#x3002;&#x5982;&#x679C;&#x4F60;&#x901A;&#x8FC7;&#x7D22;&#x5F15;&#x6570;&#x7EC4;&#x6765;&#x521B;&#x5EFA;&#x65B0;&#x7684;&#x57DF;&#xFF0C;Elasticsearch &#x4F1A;&#x7528;&#x6570;&#x7EC4;&#x4E2D;&#x7B2C;&#x4E00;&#x4E2A;&#x503C;&#x7684;&#x6570;&#x636E;&#x7C7B;&#x578B;&#x4F5C;&#x4E3A;&#x8FD9;&#x4E2A;&#x57DF;&#x7684; <code>&#x7C7B;&#x578B;</code> &#x3002;</p>
<blockquote>
<p>  <img src="assets/note.png" alt="&#x6CE8;&#x610F;">   &#x5F53;&#x4F60;&#x4ECE; Elasticsearch &#x5F97;&#x5230;&#x4E00;&#x4E2A;&#x6587;&#x6863;&#xFF0C;&#x6BCF;&#x4E2A;&#x6570;&#x7EC4;&#x7684;&#x987A;&#x5E8F;&#x548C;&#x4F60;&#x5F53;&#x521D;&#x7D22;&#x5F15;&#x6587;&#x6863;&#x65F6;&#x4E00;&#x6837;&#x3002;&#x4F60;&#x5F97;&#x5230;&#x7684; <code>_source</code> &#x57DF;&#xFF0C;&#x5305;&#x542B;&#x4E0E;&#x4F60;&#x7D22;&#x5F15;&#x7684;&#x4E00;&#x6A21;&#x4E00;&#x6837;&#x7684; JSON &#x6587;&#x6863;&#x3002;</p>
</blockquote>
<p>&#x4F46;&#x662F;&#xFF0C;&#x6570;&#x7EC4;&#x662F;&#x4EE5;&#x591A;&#x503C;&#x57DF; <em>&#x7D22;&#x5F15;&#x7684;</em>&#x2014;&#x53EF;&#x4EE5;&#x641C;&#x7D22;&#xFF0C;&#x4F46;&#x662F;&#x65E0;&#x5E8F;&#x7684;&#x3002; &#x5728;&#x641C;&#x7D22;&#x7684;&#x65F6;&#x5019;&#xFF0C;&#x4F60;&#x4E0D;&#x80FD;&#x6307;&#x5B9A; &#x201C;&#x7B2C;&#x4E00;&#x4E2A;&#x201D; &#x6216;&#x8005; &#x201C;&#x6700;&#x540E;&#x4E00;&#x4E2A;&#x201D;&#x3002; &#x66F4;&#x786E;&#x5207;&#x7684;&#x8BF4;&#xFF0C;&#x628A;&#x6570;&#x7EC4;&#x60F3;&#x8C61;&#x6210; <em>&#x88C5;&#x5728;&#x888B;&#x5B50;&#x91CC;&#x7684;&#x503C;</em> &#x3002;</p>
<p><strong>&#x7A7A;&#x57DF;</strong></p>
<p>&#x5F53;&#x7136;&#xFF0C;&#x6570;&#x7EC4;&#x53EF;&#x4EE5;&#x4E3A;&#x7A7A;&#x3002; &#x8FD9;&#x76F8;&#x5F53;&#x4E8E;&#x5B58;&#x5728;&#x96F6;&#x503C;&#x3002; &#x4E8B;&#x5B9E;&#x4E0A;&#xFF0C;&#x5728; Lucene &#x4E2D;&#x662F;&#x4E0D;&#x80FD;&#x5B58;&#x50A8; <code>null</code> &#x503C;&#x7684;&#xFF0C;&#x6240;&#x4EE5;&#x6211;&#x4EEC;&#x8BA4;&#x4E3A;&#x5B58;&#x5728; <code>null</code> &#x503C;&#x7684;&#x57DF;&#x4E3A;&#x7A7A;&#x57DF;&#x3002;</p>
<p>&#x4E0B;&#x9762;&#x4E09;&#x79CD;&#x57DF;&#x88AB;&#x8BA4;&#x4E3A;&#x662F;&#x7A7A;&#x7684;&#xFF0C;&#x5B83;&#x4EEC;&#x5C06;&#x4E0D;&#x4F1A;&#x88AB;&#x7D22;&#x5F15;&#xFF1A;</p>
<pre><code class="lang-js"><span class="hljs-string">&quot;null_value&quot;</span>:               <span class="hljs-literal">null</span>,
<span class="hljs-string">&quot;empty_array&quot;</span>:              [],
<span class="hljs-string">&quot;array_with_null_value&quot;</span>:    [ <span class="hljs-literal">null</span> ]
</code></pre>
<p><strong>&#x591A;&#x5C42;&#x7EA7;&#x5BF9;&#x8C61;</strong></p>
<p>&#x6211;&#x4EEC;&#x8BA8;&#x8BBA;&#x7684;&#x6700;&#x540E;&#x4E00;&#x4E2A; JSON &#x539F;&#x751F;&#x6570;&#x636E;&#x7C7B;&#x662F; <em>&#x5BF9;&#x8C61;</em> -- &#x5728;&#x5176;&#x4ED6;&#x8BED;&#x8A00;&#x4E2D;&#x79F0;&#x4E3A;&#x54C8;&#x5E0C;&#xFF0C;&#x54C8;&#x5E0C; map&#xFF0C;&#x5B57;&#x5178;&#x6216;&#x8005;&#x5173;&#x8054;&#x6570;&#x7EC4;&#x3002;</p>
<p><em>&#x5185;&#x90E8;&#x5BF9;&#x8C61;</em> &#x7ECF;&#x5E38;&#x7528;&#x4E8E; &#x5D4C;&#x5165;&#x4E00;&#x4E2A;&#x5B9E;&#x4F53;&#x6216;&#x5BF9;&#x8C61;&#x5230;&#x5176;&#x5B83;&#x5BF9;&#x8C61;&#x4E2D;&#x3002;&#x4F8B;&#x5982;&#xFF0C;&#x4E0E;&#x5176;&#x5728; <code>tweet</code> &#x6587;&#x6863;&#x4E2D;&#x5305;&#x542B; <code>user_name</code> &#x548C; <code>user_id</code> &#x57DF;&#xFF0C;&#x6211;&#x4EEC;&#x4E5F;&#x53EF;&#x4EE5;&#x8FD9;&#x6837;&#x5199;&#xFF1A;</p>
<pre><code class="lang-js">{
    <span class="hljs-string">&quot;tweet&quot;</span>:            <span class="hljs-string">&quot;Elasticsearch is very flexible&quot;</span>,
    <span class="hljs-string">&quot;user&quot;</span>: {
        <span class="hljs-string">&quot;id&quot;</span>:           <span class="hljs-string">&quot;@johnsmith&quot;</span>,
        <span class="hljs-string">&quot;gender&quot;</span>:       <span class="hljs-string">&quot;male&quot;</span>,
        <span class="hljs-string">&quot;age&quot;</span>:          <span class="hljs-number">26</span>,
        <span class="hljs-string">&quot;name&quot;</span>: {
            <span class="hljs-string">&quot;full&quot;</span>:     <span class="hljs-string">&quot;John Smith&quot;</span>,
            <span class="hljs-string">&quot;first&quot;</span>:    <span class="hljs-string">&quot;John&quot;</span>,
            <span class="hljs-string">&quot;last&quot;</span>:     <span class="hljs-string">&quot;Smith&quot;</span>
        }
    }
}
</code></pre>
<p><strong>&#x5185;&#x90E8;&#x5BF9;&#x8C61;&#x7684;&#x6620;&#x5C04;</strong></p>
<p>Elasticsearch &#x4F1A;&#x52A8;&#x6001; &#x76D1;&#x6D4B;&#x65B0;&#x7684;&#x5BF9;&#x8C61;&#x57DF;&#x5E76;&#x6620;&#x5C04;&#x5B83;&#x4EEC;&#x4E3A; <code>&#x5BF9;&#x8C61;</code> &#xFF0C;&#x5728; <code>properties</code> &#x5C5E;&#x6027;&#x4E0B;&#x5217;&#x51FA;&#x5185;&#x90E8;&#x57DF;&#xFF1A;</p>
<pre><code class="lang-js">{
  <span class="hljs-string">&quot;gb&quot;</span>: {
    <span class="hljs-string">&quot;tweet&quot;</span>: {                                      &lt;1&gt;
      &quot;properties&quot;: {
        &quot;tweet&quot;:            { &quot;type&quot;: &quot;string&quot; },
        &quot;user&quot;: {                                   &lt;2&gt;
          &quot;type&quot;:             &quot;object&quot;,
          &quot;properties&quot;: {
            &quot;id&quot;:           { &quot;type&quot;: &quot;string&quot; },
            &quot;gender&quot;:       { &quot;type&quot;: &quot;string&quot; },
            &quot;age&quot;:          { &quot;type&quot;: &quot;long&quot;   },
            &quot;name&quot;:   {                             &lt;3&gt;
              &quot;type&quot;:         &quot;object&quot;,
              &quot;properties&quot;: {
                &quot;full&quot;:     { &quot;type&quot;: &quot;string&quot; },
                &quot;first&quot;:    { &quot;type&quot;: &quot;string&quot; },
                &quot;last&quot;:     { &quot;type&quot;: &quot;string&quot; }
              }
            }
          }
        }
      }
    }
  }
}
</code></pre>
<blockquote>
<p> <img src="assets/1.png" alt="img">  &#x6839;&#x5BF9;&#x8C61;  </p>
<p> <img src="assets/2.png" alt="img">  <img src="assets/3.png" alt="img">   &#x5185;&#x90E8;&#x5BF9;&#x8C61;   </p>
</blockquote>
<p><code>user</code> &#x548C; <code>name</code> &#x57DF;&#x7684;&#x6620;&#x5C04;&#x7ED3;&#x6784;&#x4E0E; <code>tweet</code> &#x7C7B;&#x578B;&#x7684;&#x76F8;&#x540C;&#x3002;&#x4E8B;&#x5B9E;&#x4E0A;&#xFF0C; <code>type</code> &#x6620;&#x5C04;&#x53EA;&#x662F;&#x4E00;&#x79CD;&#x7279;&#x6B8A;&#x7684; <code>&#x5BF9;&#x8C61;</code> &#x6620;&#x5C04;&#xFF0C;&#x6211;&#x4EEC;&#x79F0;&#x4E4B;&#x4E3A; <em>&#x6839;&#x5BF9;&#x8C61;</em> &#x3002;&#x9664;&#x4E86;&#x5B83;&#x6709;&#x4E00;&#x4E9B;&#x6587;&#x6863;&#x5143;&#x6570;&#x636E;&#x7684;&#x7279;&#x6B8A;&#x9876;&#x7EA7;&#x57DF;&#xFF0C;&#x4F8B;&#x5982; <code>_source</code> &#x548C; <code>_all</code> &#x57DF;&#xFF0C;&#x5B83;&#x548C;&#x5176;&#x4ED6;&#x5BF9;&#x8C61;&#x4E00;&#x6837;&#x3002;</p>
<p><strong>&#x5185;&#x90E8;&#x5BF9;&#x8C61;&#x662F;&#x5982;&#x4F55;&#x7D22;&#x5F15;&#x7684;</strong></p>
<p>Lucene &#x4E0D;&#x7406;&#x89E3;&#x5185;&#x90E8;&#x5BF9;&#x8C61;&#x3002; Lucene &#x6587;&#x6863;&#x662F;&#x7531;&#x4E00;&#x7EC4;&#x952E;&#x503C;&#x5BF9;&#x5217;&#x8868;&#x7EC4;&#x6210;&#x7684;&#x3002;&#x4E3A;&#x4E86;&#x80FD;&#x8BA9; Elasticsearch &#x6709;&#x6548;&#x5730;&#x7D22;&#x5F15;&#x5185;&#x90E8;&#x7C7B;&#xFF0C;&#x5B83;&#x628A;&#x6211;&#x4EEC;&#x7684;&#x6587;&#x6863;&#x8F6C;&#x5316;&#x6210;&#x8FD9;&#x6837;&#xFF1A;</p>
<pre><code class="lang-js">{
    <span class="hljs-string">&quot;tweet&quot;</span>:            [elasticsearch, flexible, very],
    <span class="hljs-string">&quot;user.id&quot;</span>:          [@johnsmith],
    <span class="hljs-string">&quot;user.gender&quot;</span>:      [male],
    <span class="hljs-string">&quot;user.age&quot;</span>:         [<span class="hljs-number">26</span>],
    <span class="hljs-string">&quot;user.name.full&quot;</span>:   [john, smith],
    <span class="hljs-string">&quot;user.name.first&quot;</span>:  [john],
    <span class="hljs-string">&quot;user.name.last&quot;</span>:   [smith]
}
</code></pre>
<p><em>&#x5185;&#x90E8;&#x57DF;</em> &#x53EF;&#x4EE5;&#x901A;&#x8FC7;&#x540D;&#x79F0;&#x5F15;&#x7528;&#xFF08;&#x4F8B;&#x5982;&#xFF0C; <code>first</code> &#xFF09;&#x3002;&#x4E3A;&#x4E86;&#x533A;&#x5206;&#x540C;&#x540D;&#x7684;&#x4E24;&#x4E2A;&#x57DF;&#xFF0C;&#x6211;&#x4EEC;&#x53EF;&#x4EE5;&#x4F7F;&#x7528;&#x5168; <em>&#x8DEF;&#x5F84;</em> &#xFF08;&#x4F8B;&#x5982;&#xFF0C; <code>user.name.first</code> &#xFF09; &#x6216; <code>type</code> &#x540D;&#x52A0;&#x8DEF;&#x5F84;&#xFF08; <code>tweet.user.name.first</code> &#xFF09;&#x3002;</p>
<blockquote>
<p> <img src="assets/note.png" alt="&#x6CE8;&#x610F;">  &#x5728;&#x524D;&#x9762;&#x7B80;&#x5355;&#x6241;&#x5E73;&#x7684;&#x6587;&#x6863;&#x4E2D;&#xFF0C;&#x6CA1;&#x6709; <code>user</code> &#x548C; <code>user.name</code> &#x57DF;&#x3002;Lucene &#x7D22;&#x5F15;&#x53EA;&#x6709;&#x6807;&#x91CF;&#x548C;&#x7B80;&#x5355;&#x503C;&#xFF0C;&#x6CA1;&#x6709;&#x590D;&#x6742;&#x6570;&#x636E;&#x7ED3;&#x6784;&#x3002;</p>
</blockquote>
<p><strong>&#x5185;&#x90E8;&#x5BF9;&#x8C61;&#x6570;&#x7EC4;</strong></p>
<p>&#x6700;&#x540E;&#xFF0C;&#x8003;&#x8651;&#x5305;&#x542B; &#x5185;&#x90E8;&#x5BF9;&#x8C61;&#x7684;&#x6570;&#x7EC4;&#x662F;&#x5982;&#x4F55;&#x88AB;&#x7D22;&#x5F15;&#x7684;&#x3002; &#x5047;&#x8BBE;&#x6211;&#x4EEC;&#x6709;&#x4E2A; <code>followers</code> &#x6570;&#x7EC4;&#xFF1A;</p>
<pre><code class="lang-js">{
    <span class="hljs-string">&quot;followers&quot;</span>: [
        { <span class="hljs-string">&quot;age&quot;</span>: <span class="hljs-number">35</span>, <span class="hljs-string">&quot;name&quot;</span>: <span class="hljs-string">&quot;Mary White&quot;</span>},
        { <span class="hljs-string">&quot;age&quot;</span>: <span class="hljs-number">26</span>, <span class="hljs-string">&quot;name&quot;</span>: <span class="hljs-string">&quot;Alex Jones&quot;</span>},
        { <span class="hljs-string">&quot;age&quot;</span>: <span class="hljs-number">19</span>, <span class="hljs-string">&quot;name&quot;</span>: <span class="hljs-string">&quot;Lisa Smith&quot;</span>}
    ]
}
</code></pre>
<p>&#x8FD9;&#x4E2A;&#x6587;&#x6863;&#x4F1A;&#x50CF;&#x6211;&#x4EEC;&#x4E4B;&#x524D;&#x63CF;&#x8FF0;&#x7684;&#x90A3;&#x6837;&#x88AB;&#x6241;&#x5E73;&#x5316;&#x5904;&#x7406;&#xFF0C;&#x7ED3;&#x679C;&#x5982;&#x4E0B;&#x6240;&#x793A;&#xFF1A;</p>
<pre><code class="lang-js">{
    <span class="hljs-string">&quot;followers.age&quot;</span>:    [<span class="hljs-number">19</span>, <span class="hljs-number">26</span>, <span class="hljs-number">35</span>],
    <span class="hljs-string">&quot;followers.name&quot;</span>:   [alex, jones, lisa, smith, mary, white]
}
</code></pre>
<p><code>{age: 35}</code> &#x548C; <code>{name: Mary White}</code> &#x4E4B;&#x95F4;&#x7684;&#x76F8;&#x5173;&#x6027;&#x5DF2;&#x7ECF;&#x4E22;&#x5931;&#x4E86;&#xFF0C;&#x56E0;&#x4E3A;&#x6BCF;&#x4E2A;&#x591A;&#x503C;&#x57DF;&#x53EA;&#x662F;&#x4E00;&#x5305;&#x65E0;&#x5E8F;&#x7684;&#x503C;&#xFF0C;&#x800C;&#x4E0D;&#x662F;&#x6709;&#x5E8F;&#x6570;&#x7EC4;&#x3002;&#x8FD9;&#x8DB3;&#x4EE5;&#x8BA9;&#x6211;&#x4EEC;&#x95EE;&#xFF0C;&#x201C;&#x6709;&#x4E00;&#x4E2A;26&#x5C81;&#x7684;&#x8FFD;&#x968F;&#x8005;&#xFF1F;&#x201D;</p>
<p>&#x4F46;&#x662F;&#x6211;&#x4EEC;&#x4E0D;&#x80FD;&#x5F97;&#x5230;&#x4E00;&#x4E2A;&#x51C6;&#x786E;&#x7684;&#x7B54;&#x6848;&#xFF1A;&#x201C;&#x662F;&#x5426;&#x6709;&#x4E00;&#x4E2A;26&#x5C81; <em>&#x540D;&#x5B57;&#x53EB; Alex Jones</em> &#x7684;&#x8FFD;&#x968F;&#x8005;&#xFF1F;&#x201D;</p>
<p>&#x76F8;&#x5173;&#x5185;&#x90E8;&#x5BF9;&#x8C61;&#x88AB;&#x79F0;&#x4E3A; <em>nested</em> &#x5BF9;&#x8C61;&#xFF0C;&#x53EF;&#x4EE5;&#x56DE;&#x7B54;&#x4E0A;&#x9762;&#x7684;&#x67E5;&#x8BE2;&#xFF0C;&#x6211;&#x4EEC;&#x7A0D;&#x540E;&#x4F1A;&#x5728;<a href="https://www.elastic.co/guide/cn/elasticsearch/guide/current/nested-objects.html" target="_blank"><em>&#x5D4C;&#x5957;&#x5BF9;&#x8C61;</em></a>&#x4E2D;&#x4ECB;&#x7ECD;&#x5B83;&#x3002;</p>
<footer class="page-footer"><span class="copyright">Copyright &#xA9; WS 2019 all right reserved&#xFF0C;powered by Gitbook</span><span class="footer-modification">&#x8BE5;&#x6587;&#x4EF6;&#x4FEE;&#x8BA2;&#x65F6;&#x95F4;&#xFF1A;
2019-03-08 11:37:23
</span></footer>
                                
                                </section>
                            
    </div>
    <div class="search-results">
        <div class="has-results">
            
            <h1 class="search-results-title"><span class='search-results-count'></span> results matching "<span class='search-query'></span>"</h1>
            <ul class="search-results-list"></ul>
            
        </div>
        <div class="no-results">
            
            <h1 class="search-results-title">No results matching "<span class='search-query'></span>"</h1>
            
        </div>
    </div>
</div>

                        </div>
                    </div>
                
            </div>

            
                
                <a href="2_1_Introductory.html#代价较小的批量操作" class="navigation navigation-prev " aria-label="Previous page: 代价较小的批量操作">
                    <i class="fa fa-angle-left"></i>
                </a>
                
                
                <a href="2_2_Introductory.html#路由一个文档到一个分片中" class="navigation navigation-next " aria-label="Next page: 路由一个文档到一个分片中">
                    <i class="fa fa-angle-right"></i>
                </a>
                
            
        
    </div>

    <script>
        var gitbook = gitbook || [];
        gitbook.push(function() {
            gitbook.page.hasChanged({"page":{"title":"分布式文档存储","level":"3.1.4","depth":2,"next":{"title":"路由一个文档到一个分片中","level":"3.1.4.1","depth":3,"anchor":"#路由一个文档到一个分片中","path":"2_2_Introductory.md","ref":"2_2_Introductory.md#路由一个文档到一个分片中","articles":[]},"previous":{"title":"代价较小的批量操作","level":"3.1.3.13","depth":3,"anchor":"#代价较小的批量操作","path":"2_1_Introductory.md","ref":"2_1_Introductory.md#代价较小的批量操作","articles":[]},"dir":"ltr"},"config":{"plugins":["github@^2.0.0","edit-link@^2.0.2","anchors@^0.7.1","include-codeblock@^3.0.2","splitter@^0.0.8","tbfed-pagefooter@^0.0.1","expandable-chapters-small@^0.1.7","anchor-navigation-ex@0.1.8","book-summary-scroll-position-saver","ace","emphasize","-lunr","-search","search-plus"],"styles":{"website":"styles/website.css","pdf":"styles/pdf.css","epub":"styles/epub.css","mobi":"styles/mobi.css","ebook":"styles/ebook.css","print":"styles/print.css"},"pluginsConfig":{"tbfed-pagefooter":{"copyright":"Copyright © WS 2019","modify_label":"该文件修订时间：","modify_format":"YYYY-MM-DD HH:mm:ss"},"emphasize":{},"ace":{},"github":{"url":"https://github.com/wjw465150/Elasticsearch"},"book-summary-scroll-position-saver":{},"splitter":{},"fontsettings":{"theme":"white","family":"sans","size":2},"highlight":{},"anchor-navigation-ex":{"isRewritePageTitle":false,"tocLevel1Icon":"fa fa-hand-o-right","tocLevel2Icon":"fa fa-hand-o-right","tocLevel3Icon":"fa fa-hand-o-right"},"expandable-chapters-small":{},"include-codeblock":{"check":false,"edit":true,"fixlang":false,"lang":"","template":"ace","theme":"chrome","unindent":true},"sharing":{"facebook":true,"twitter":true,"google":false,"weibo":false,"instapaper":false,"vk":false,"all":["facebook","google","twitter","weibo","instapaper"]},"edit-link":{"label":"编辑此页面","base":"https://github.com/wjw465150/Elasticsearch/edit/master"},"theme-default":{"styles":{"website":"styles/website.css","pdf":"styles/pdf.css","epub":"styles/epub.css","mobi":"styles/mobi.css","ebook":"styles/ebook.css","print":"styles/print.css"},"showLevel":false},"anchors":{},"search-plus":{}},"theme":"default","author":"WS","pdf":{"pageNumbers":true,"fontSize":12,"fontFamily":"Arial","paperSize":"a4","chapterMark":"pagebreak","pageBreaksBefore":"/","margin":{"right":62,"left":62,"top":56,"bottom":56}},"structure":{"langs":"LANGS.md","readme":"README.md","glossary":"GLOSSARY.md","summary":"SUMMARY.md"},"variables":{},"title":"Elasticsearch权威指南中文版","language":"zh-hans","gitbook":"*","description":"Elasticsearch权威指南中文版"},"file":{"path":"2_2_Introductory.md","mtime":"2019-03-08T03:37:23.313Z","type":"markdown"},"gitbook":{"version":"3.2.3","time":"2019-03-15T05:52:05.244Z"},"basePath":".","book":{"language":""}});
        });
    </script>
</div>

        
    <script src="gitbook/gitbook.js"></script>
    <script src="gitbook/theme.js"></script>
    
        
        <script src="gitbook/gitbook-plugin-github/plugin.js"></script>
        
    
        
        <script src="gitbook/gitbook-plugin-edit-link/plugin.js"></script>
        
    
        
        <script src="gitbook/gitbook-plugin-splitter/splitter.js"></script>
        
    
        
        <script src="gitbook/gitbook-plugin-expandable-chapters-small/expandable-chapters-small.js"></script>
        
    
        
        <script src="gitbook/gitbook-plugin-book-summary-scroll-position-saver/book-summary-scroll-position-saver.js"></script>
        
    
        
        <script src="gitbook/gitbook-plugin-ace/ace/ace.js"></script>
        
    
        
        <script src="gitbook/gitbook-plugin-ace/ace.js"></script>
        
    
        
        <script src="gitbook/gitbook-plugin-search-plus/jquery.mark.min.js"></script>
        
    
        
        <script src="gitbook/gitbook-plugin-search-plus/search.js"></script>
        
    
        
        <script src="gitbook/gitbook-plugin-sharing/buttons.js"></script>
        
    
        
        <script src="gitbook/gitbook-plugin-fontsettings/fontsettings.js"></script>
        
    

    </body>
</html>

